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SECTION I 

INTRODUCTION 

LI PURPOSE 

This Manual provides the technical information necessary to install, operate ana maintau. 
the SUPER SIX singleboard computer by Advanced Digital Corporation. 

L2 EQUIPMENT OVERVIEW 

SUPER SIX, produced by Advanced Digital Corporation, is the first single boara computer 
for the S~100 bus running at 6MHz. Without the S-100 bus the SUPER SIX can also run as 
a standalone computer executing a single user CP/M 2.2 or 3.0, or a multiuser MP/M, 
OASIS, or TurboDOS operating system. SUPER SIX runs substantially faster than any 
other S-100 single board computer avialable in the market. 

The SUPER SIX contains the following set of capabilities: 

1. Z80B CPU operating at 6MHZ 

2. 128K of dynamic bank select RAM arranged in I6k banks 

3. Floppy Disk Controller which supports the 8-inch and 5.25-inch disk 
drives simultaniously 

'f, 21k K of shadow EPROM (Monitor) 

5. 2 serial I/O (RS-232) ports offering software or hardware selectable 
baud rate, Z80B DART 

6. 2 parallel ports (Z8QB PIO) 

7. Real time clock (Z80B CTC) 

8. DMAcontroller (Z80 DMA) 

9. Extended addressing: A 16- A23 

10. Single 5 volt supply on board 
li. One-year warranty 

12. Free copy of CP/M 2.2 BIOS supplied. 

* NOTE; Items 5 and 6 require external adaptation for 
RS-232 and Centronics. The adapter boards contain a 
DB-25 connector on a 2-inch by 2-inch board attached to 
the back panel of the S-100 system (MODEM and RS ^22 
Paddle cards are also available). 
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This document is organized into > sections and H appendices. 

Section I serves as an introduction to the entire document, stating the purpose of the 
document and providing an introduction to the SUPER SIX single board computer. This 
section also provides a list of acronyms used in the document and provides a statement on 
the responsibilities of document maintenance. 

Section II provides a description of the operations of all components associated with the 
SUPER SIX single board computer. 

Section III lists all SUPER SIX input/output ports and defines the assignments and 
functions of each port. 

Section IV lists and defines all SUPER SIX jumper connections. This section includes the 
jumper assignments for factory (OEM) installed jumpers. 

Section V describes the external connector pins for SUPER SIX connectors 31 through 35. 

The appendices provide supplemental material to the body of the text antlare referenced 
in the text at the associated points. 
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LIST OF ACRONYMS 



Table l~i provides a listing and description of the acronyms used vi/ithin this text. 



ACRONYM 


DESCRIPTION 


CPU 


Central Processor Unit 


CTC 


Controller/Timer Circuit 


DART 


Dual Asynchronous Receiver/Transmitter 


DMA 


Direct Memory Access 


EPROM 


Electrically Erasable Programmable Read-Only Memory 


FDC 


Floppy Disk Controller 


IEEE 


Institute of Electrical and Electronic Engineers 


MP/M 


Multiuser Program For Microcomputers 


OEM 


Original Equipment Manufacturer 


PIO 


Parallel Input/Output 


PROM 


Programmable Read-Only Memory 



Table 1-1. List of Acronyms 
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Table 1-1. List of Acronyms (Continued) 






ACRONYM 


DtSCRIFTION 






RAM 


Random Access Memory 






SIO 


Serial Input/Output 






TTL 


Transistor-transistor Logic 






TurboDOS 


A Multiuser Networking Operating System used as software 
SUPER SIX 


with the 



L5 DOCUMENT MAINTENANCE 

This document is the property of Advanced Digital Corporation, who is responsible for its 
content. Any modifications made to this manual must be made with the express written 
approval of Advanced Digital Corporation, 

1.6 THEORY OF OPERATION - START-UP PROCEDURE 

The SUPER SIX Single board computer is shipped configured for 19. baud rate. The 
installation procedure is as follows: 

1. Plug the PSNET/I to connector 35. Use caution; pin I is marked. 

2. Connect the CRT. Pins 2, 3, 5, 7, and 20 must be used; no parity 
must be specified, 

3. Apply power to the system. The monitor message shown in 
subsection 2.9,2 appears. Check the CRT baud rate; if 9600 baud is 
required, unplug jumper area 37, pin 7-8. 

,4. Install the floppy disk cable, load the CP/M diskette, and bootstrap 
the system. 

Note? CP/M is shipped configured for 64K bytes of 
memory. The parallel port is configured as the default 
printer. 1024 bytes per sector read/writes are also 
supported (or DMA). The plus SV and the plus/minus 16V 
on the S~I00 bus must be verified prior to installing the 
SUPER SIX board. 
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SECTION II 
OPERATION 

This section describes the operation ol ah SUPER SIX components. 

2.1 FLOPPY DISK CONTROLLER 

The floppy disk controller can access up to four S-inch or four 5.25-inch disk drives or any 
combination of the two. The controller can read and write IBM 37^*0 single density format 
and double density 102^* sector-size formats. Data transfer is performed via Direct 
Memory Access (DMA). Due to the simultanious operation capability of the SUPER SIX 
the format compatibility problems with 5.25-inch disks have been eliminated. The floppy 
disk controller used is the W 027^3. The WD2793 has on-chip PLL data separators and 
on-chip write pre -compensation logic. Adjustments for PLL are factory set ana write 
pre-compensation has been provided with the SUPER SIX. 50 Pin and 3U pin connectors 
are available for 8-inch and 5.25-inch disk drives respectively. 

NOTE: Customer adjustment of trim pots 
may result in cancellation of warranty. 

2.2 THE t28K DYNAMIC RAM 

The 128K RAM array can be switched ON and OFF in 16K increments, (O-IbK, 16K-32K, 
32K-^8K, 48K-6'^K for both banks) under software control. This feature allows the CPU 
to access bank switchable external memory on the S-100 bus. The memory has an access 
time of 150ns. A Refresh operation is performed during Z80 Ml cycles and during WAIT 
and RESE1 states. The memory can be accessed by floppy disk via DMA, serial and 
parallel I/O, or another DMA device on the S-lOO bus. 

*NOTE: Any external DMA device that is 
using continous mode DMA cycles must 
transfer data at an average rate of I5ms per 
byte or faster when holding the DMA request 
line for more than 1.5ms. The RAM row 
address is the low order address; therefore 
the entire RAM array is refreshed by DMA 
device every 128 contiguous memory cycles. 

Under CPM 2.2 or CPM 3.0 the additional 6^K can be used as a disk butter. The SUPER 
SIX is ideal when operating in the bank mode under CP/M 3.0, as 128K RAM is required. 



2.3 SYSTEM MONiTOK EPHQM 

The system monitor EPROM is switched ON during reset. Il f on be disablea oTiG enabled 
under software control. When enabled, the system monitor resides at locations 
F800-FFFF (hex) (refer to subsection 2.y.l.2) when using 2716 lFKOM or at locations 
FOOO-FFFF (hex) when using the 2732 EPROM. The systeirr monitor LFKOM contains the 
cold-start loader for CP/M, MP/M and lurboDOb. In adaiiion it can be used to perform 
LOAD, I/O READ and I/O WRITE operations. When the LPHO.Vi is disabled no system 
address space is used. 

2.4 SERIAL PORTS 

A 6MHz Z80B DART is used for the two serial I/O ports; a Z80B SIO or Z80A DART can 
be used in it's place (if a Witiz Z80A DART is used the CPU and all other devices must 
also be H^Mtiz). This allows asynchronous serial data communication plus a variety of 
interrupt modes. Modem control signals are available at each serial connector. There are 
software selectable baud rates as well as hardware selectable baud rates (mini-jumpers 
37). 

*NOTE: The serial ports are TTL and must 
be connected to PSNET/1 (serial adapter 
interface) for RS-232 communications. The 
3>4- connector is for the CRT; the 35 
connector is for the serial printer or CRT. 

2.5 PARALLEL PORTS 

A 6MHz Z80B PIO is used as the parallel port. The "A" channel of this chip is used to 
connect the parallel port connector (32) to PIO. This port has an 8-bit bi-directional data 
line and two hand-shake lines. The "B" port can be split between the parallel port 
connector and the 5-100 bus vectored interrupts lines by jumper options. This allows the 
port to be used as an additional parallel port, an interrupt controller, or both of the 
above. In the output mode the parallel ports can drive one TTL load. 

^.6 REAL TIME INTERRUPT oLOCK 

A 6MHz Z80B CTC is used for providing a real time system clock for MP/M or TurboDOS 
operating systems. Three channels of the CTC are available to the user for jumpering to 
synchronous baud rates or long clock times. 

2.7 S-IOOBUS INTERFACE 

The S-100 bus interface provides the signals necessary for an 8-bit bus master as 
described by the IEEE-696 bus specification. Vectored interrupt lines V10-V17 are 
supported via jumper options (refer to section IV) and A16-A23 are also supported via an 
I/O port. The Phantom line is also implemented for the dynamic RAM array. 

The SUPER SIX interface with the S-lOO bus is depicted in Figure 2-1. 

TurboDOS is the registered trademark of Software 2000, inc. 

CP/M and MP/M are the registered trademarks of Digital Research, Inc. 
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2.8 



BAUD RATE JUMPER 



Upon SUPER SIX initialization, the baud rate for the two serial channels can be 
hardware-selected independently by means of the baud rate jumper 07). This 7-pole 
jumper is located between U70 and U68 and is divided into two sets of jumpers containing 
four and three pins for SIO channels A and B, respectively. Pins 7, 6, 5, and 4 set the baud 
rate for SIO channel A and are designated as A, B, C, and D, respectively; pins 3, 2, and 1 
set the baud rate for SiO channel B and are designated as A, B, and C, respectively. 
Because this jumper comprises of only seven pin sets, SIO channel B has a hardware 
limitation of 1200 baud; by means of port 18 the software may be set to allow up to I9.2K 
baud for channel B. The baud rate settings, as determined by this jumper, are shown in 
Table 2~I, below. Once the SUPER SIX is initialized, I/O port 18 is used to modify the 
baud rate. Port 18 is described in subsection 3.2.21. 



BIT 


BIT 


BIT 


BIT 


BAUD 


D 


C 


B 


A 


RATE 














50 











1 


75 








1 





110 








1 


I 


134.5 





1 








150 





1 





1 


300 





1 


i 





600 





1 


1 


1 


1200 













1800 










1 


2000 







1 





2400 







I 


1 


3600 




I 








4800 




I 





I 


7200 




1 


1 





9600 




1 


I 


I 


19,200 



2.9 



Table 2-1. SUPER SIX Baud Rate Jumper Settings 
EPROM AND MONITOR OPERATION 



The on-board EPROM occupies addresses FOOO-FFFF (hex). This EPROM is switched ON 
automatically during RESET or POWER-ON. It contains the serial input/output (SIO) and 
floppy disk controller (FDC) initialization code along with a simple debugger and floppy 
disk cold-start loader. After the operating system is loaded the EPROM can be turned 
OFF to allow access to the RAM at address FOOOH-FFFFH. The EPROM can be enabled 
or disabled at any time to permit the calling of hardware dependant I/O routines. 

2.9.1 EPROM Enable/Disable 

A listing of the program required to enable and disable the EPROM is provided below 



BAUD RATE JUMPERS 

ADVANCED DIGITAL CORPORATION SUPER SIX SUPPLEMENT 

Update for Page 7 

With the Super Six component side facing you and the S-100 connector down there 
are 7 jumpters between U68 and U70 aligned vertically. There are assigned as 
follows: 



console -SIO CH. A= 



-SIO CH. B= 




nil 


bit 


A 


nil 


bit 


B 


nil 


bit 


C 


.nil 


bit 


D 


nil 


bit 


A 


nil 


bit 


B 


iiii 


bit 


C 



JUMPER INSTALLED = 1 
JUMPER OFE = 



Bit D for SIO CH. B is not available as a jumper and must be set in software. 
Bit 7 of this input, port (port 15) is instead used to sense double sided drives. 
Some software reads this bit and sends it to the SIO CH. B baud rate anyway. If 
you have double sided drives, this will make the bit a thru creating baud rates 
from 50 to 1200. If you have single sided drives, this will make the bit a 1 
and create baud rates from 1800 to 19. 2K. If you experience a problem with this 
you can make a file under cpm to correctly assign the baud rate to SIO CH. B 
(used for serial printer and/or modem) as follows: 



-alOO 




0100 


in 15 


0102 


ani 7f 


0104 


out 18 


0106 


jmp 


0109 


<CR> 


-gO 




A>save 


1 setbaud.com 


A>setbaud 



(for 50 to 1200 baud. 
19.2k type ori 80) 



for 1800 to 



COMMON BAUD RATE SETTINGS 



Console = 


19 


.2k 


Console = 


19. 


.2k 


Console = 9600 


Console 


SIO CH. B 


= 


300 


SIO 


CH. B 


= 1200 






(ON ) 








(ON ) 






(off) 


(ON ) 


(ON ) 








(ON ,) 






(ON ) 


(ON ) 


(ON ) 








(ON ) 






(ON ) 


(ON ) 


(ON ) 








(ON ) 






(ON ) 


(off) 


(ON ) 








(ON ) 










(off) 








(ON ) 










(ON ) 








(ON ) 











= 12 
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2.9 J J Enabling the EPROM: 

F033 3E4F MVJA,OiOOmiB . ;RESET POWER ON JUMP AND 

ENABLE MEMORY, EPROM ON 
F035 D316 OUT I6H ;WRITE TO CONTROL PORT 

2.9.1,2 Disabling the EPROM: 

F033 3E'tF MVI A,0I1011I1B ;RE5ET POWER ON 3UMP AND 

ENABLE MEMORY, EPROM OFF 
F035 D316 OUT 16H ;WRITE TO CONTROL PORT 

Jumper R25 configures the board to accept a 2716 or 2732 EPROM (as described in 
section IV). 

NOTE: The EPROM is always addressed at 
location F800 (hex) and can not be moved. 
Since the 2716 EPROM is 2K long it appears 
twice, at location F800-FC00 (hex) and at 
location FBFF-FFFF (hex). 

2.9.2 Monitor Sign-on 

The monitor signs-on with the following messages: 

ADVANCED DIGITAL CORP. 
Monitor Version 3.6 
April - 1983 
Press "H" for help 

2.9.3 Monitor Commands 

The monitor commands are shown in table 2-2. 
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COMMAND 


FUNCTION 


B 


Loads the disk-boot loader 


D ssss qqqq 


Dumps memory in hex starting at user-specified address 
ssss and ending at user-specilied address qqqq 


F ssss qqqq bb 


Fills memory from user-specified address ssss to 
user-specified address qqqq with bb 


G AAAA 


Goes to address AAAA 


IPP 


Input to user-specified port pp 


L aaaa 


Loads memory starting at user-specified address aaaa 


M ssss qqqq dddd 


Moves the contents of user-specified starting address 
ssss through user-specified ending address qqqq to the 
user-specifiea starting address of dddd 


Oppdd 


Output user-specified data dd to port pp 


ESC 


Terminates any command / 



Table 2-2. Monitor Commands For the SUPER SIX 



The cold-start loader will select and home drive 0. Track sector 1 will be read into 
memory at location 0. Single density is assumed for track 0. If an error occures an error 
code will be printed. The error code must be translated using the table in appendex G. 



2.3A Cold Start Program 

The cold start program is listed below. 









;RtAD TRACK SECTION 1 INTO 








MEMORY 






BOOT 5 


: 




MVI 


A,018H 






OUT 


WAIT 

BOOT: 


;set double for 5 inch 


F4B5 3E0D 


MVI 


A,0DH 


•^ESET FDC 


F4B7 D30C 


OUT 


FDC 


;ISSUE COMMAND 


F^B9 00 


NOP 










FDCWl 


: 


F^BA DBOC 


IN 


FDC 


" ;CHECK BUSY 


F^BC OF 


RRC 






F*BD DABAFij 


3C 


FDCWl 




F^CO 00 


NOP 




;KILL TIME 


F^Cl 00 


NOP 






F^C2 00 


NOP 






Fi*C3 00 


NOP 






F4C4 3E03 


MVI 


A,3 


;GET A RESTORE 


F'fCe D30C 


OUT 


FDC 


;ISSUE' COMMAND 


F'tCS 00 


NOP 






F^C9 DBl^f 


IN 


WAIT 


;WAIT»FOR 


F<tCB 00 


NOP 


TKO: 


1INTRI5 


F4CC DBOC 


IN 


FDC 




F4CE E60f 


ANI 


4 


jCHECK TRACK 


F^DO CACCF4 


3Z 


TKO 




Fi^D3 AF 


XRA 


A 




F4D^ 6F 


MOV 


L,A 


jPOINT AT LOC 


F^D5 67 


MOV 


H,A 




F4D6 3C 


INR 


A 




F^D7 D30E 


OUT 


FDCSEC 


;SETSE"CTOR 


F^D9 3E8C 


MVI 


A,08CH 


;GET READ COMMAND 


F4DB D30C 


OUT 


FDC 


;ISSUE COMMAND 


F4DD 00 


NOP 




<■ 






FDCRD 


•: ■ 


F4DE DB14 


IN 


WAIT 


;WAlt FOR INTRQ 


F4E0 B7 


OR A 


A 


;0R DRO 


F4E1 F2EBF4 


3P 


BOOTDN 


lEXlt IF INTRQ 


F^jE^ DBOF 


IN 


FDCDATA 


iGCT DATA 


F^E6 77 


MOV 


M,A 


;STORE 


Fi>E7 23 


INX 


H 


;POJNT NEXT 


F^E8 C3DEF4 


3MP 


FDCRD 
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BOOTDN: 


F4EB DBOC 


IN 


FDC 


;CHECK SI ATUS 


F^ED B7 


OR A 


A 


;0 - NO ERROR 


F4EE CAOOOO 


32. 





,OK, GO 


F4F1 F5 


PUSH 


PSW 


;SAVE ERROR 


F^F2 210FF6 


LXI 


H,BTERR 


iPRINT 


F<fF5 CDE6F0 


CALL 


MSG 


;DISK ERROR 


F^F8 Fl 


POP 


PSW 


;GET ERROR 


F^F9 CD21F1 


CALL 


THXB 


;PRINT IT 


10 


RAM ORGANIZATION 





The SUPER SIX i28K RAM is configured as shown in Figure 2-2. 



U55 


U46 


U47 


U57 


U48 


U56 


U58 


U49 


U50 


U60 


U51 


U59 


U61 


U52 


U53 


U63 


U54 


U62 



Figure 2-2. SUPER SIX RAM Configuration 

The first 64K bank of RAM comprises of Uif6, Uii7, U^8, m9, U5i, U52, U5^, U53, and 
U50| U^6 is the parity chip. 
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Z80A DMA FEATURES 



The Z80A DMA performs transfers, searches and search/transfers on a full-byte basis in 
burst or continuous modes. The cycle length and edge timing can be programmed to 
match the speed of any port. A bit maskable byte search can be performed either 
concurrently with transfers or as an operation itself. 
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PSNET/1 OPERATION 



This paddle card converts TTL to RS232 levels. Pin 6 of the 14 pin connector on the card 
represents TXD; pin 7 is RTS*; pin 8 is DTR*; pin 5 is CTS*; 1 is DCD* (normally GND); 3 
is RNG* optional; 2 is DSR*; 4 is RXD. Only pins 3, 5, 20, 2, and 1 are required for most 
printers or CRT's. Printers employing the BUSY line must be tied to pin 20 of the DB-25 
connector on PSNET/1. A PSNET/1 schematic is provided in Appendix L. 
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2.J3 PSNET/FAR 

This paddle card connects the SUPER SIX parallel I/O to a Centronics printer or any other 
device that requires buffered signals. Note that a DB-25 connector is used to simplify the 
connection for the back panel of the S-100 system. Thirteen wires are required between 
the DB-25 and the printer. A PSNET/PAR schematic is provided in Appendix M. 

2.1if SYNCHRONOUS OPERATlQhS 

If synchronous operation is required, the CTC channels (all four) are unused; the jumper 
option on H and T can be used to bring external clock into the SIO. The 1<* pin connectors 
(34 and 35), pins 1 and 11, are not used and can be employed for RNG. SIO pins 13 and 14 
are connected on the SUPER SIX board and must be cut for synchronous operation. 

2.15 POWER CONSUMPTION 

+8V 2.8 Amp typical 

+/-16V 250 ma 
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SECTION m 
INPUT/OUTPUT PORTS 

3-1 INPUT/OUTPUT PORT ASSIGNMENTS 

Input/Output port assignments are shown in Table 3-1; 



ADDRESS 



FUNCTION 



00 
01 
02 

03 

0«f 

05 

06 

07 

08 

09 

OA 

OB 

OC 

OD 

OE 

OF 

10 

11 

12 

3 

ti- 

5 

5 

6 

7 

8 

9 

lA 
IB 



Read/Write 

Read/Write 

Read/Write 

Read/Write 

Read/Write 

Write 

Read/Write 

Write 

Read/Write 

Read/Write 

Read/Write 

Read/Write 

Read/Write 

Read/Write 

Read/Write 

Read/Write 

Read/Write 

Read/Write 

Read/Write 

Read/ Write 

Read/Write 

Write 

Read 

Write 

Write 

Write 

Write 

Write 

Write 



SIO channel A Data port 

SIO channel A status/control port 

SIO channel B Data port 

SIO channel B status/control port 

PIO channel A Data port 

PIO channel B Data port 

PIO channel A control port 

PIO channel B control port 

CTC channel control port 

CTC channel I control port 

CTC channel 2 control port 

CTC channel 3 control port 

FDC command/status port 

FDC Track register 

FDC sector register 

FDC data port 

DMA control port 

Same as port 10 

Same as port 10 

Same as port 10 

FDC synchronization/Drive/Density 

S-100 bus extended address A16-A23 

On-board Baud Rate jumpers 

On-board memory control port #0 

On-board memory control port #1 

Set Baud Rate 

Same as port 18 

Same as port 18 

Same as port 18 



Table 3-L I/O Port Assignments for the SUPER SIX Board 

Note: All Address in table 3-1 are listed in Hex. 
The unused input/output ports are internally 
decoded and should not be used by external S-100 
I/O boards. 

The individual ports are described in detail in the following subsection. 
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3.2 I/O PORT DESCRIPTIONS 

This subsection discribes the function of all SUPER SIX I/O ports. 

3.2.1 Port 00 

This read/write port acts as the serial input/output channal A data port and is described in 
detail in Appendix A. 

3.2.2 Port 01 

This read/write port acts as the serial input/output channel A status/control port and is 
discribed in Appendix A. 

3.2.3 Port 02 

This read/write port acts as the serial input/output channel B data port and is discribed in 
detail in Appendix A. 

3.2.^ Port 03 

This read/write port acts as the serial input/output channel B status/control port and is 
described in detail in Appendix A. 

3.2.5 Port 0^ 

This read/write port acts as the parallel input/output channel A data port and is discribed 
in detail in Appendix B. 

3.2.6 Port 03 

This write-only port acts as the parallel input/output channel B data port and is 
described in detail in Appendix B. This port can be jumpered to the S-100 vectored 
intercept lines onto connector 32 (refer to Section IV). 

3.2.7 Port 06 

This read/write port acts as the parallel input/output channel A control is discribed 
in detail in Appendix B. 

3.2.8 Port 07 

This write-only port acts as the parallel input/output channel B control port and is 
described in detail in Appendix B, This port can be jumpered to the S-100 vectored 
interrupt lines onto connector 32 (refer to Section IV). 

3.2.9 Port 08 

This read/write port acts as the counter/timer circuit channel zero control port and is 
discribed in detail in Appendix C- 
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XIAO Port 09 

This read/write port acts as the counter/timer circuit channel 1 control port and is 
discribed in detail in Appendix C. 

3.2.11 Port OA 

This read/write port acts as the counter/timer circuit channel 2 control port and is 
discribed in detail in Appendix C. 

3.2.12 Port OB 

This read/write port acts as the counter/timer circuit channel 3 control port and is 
described in detail in Appendix C. 

3.2.13 Port OC 

This read/write port acts as the floppy disk control command and status port and is 
described in detail in Appendix F. 

3.2.1^ Port OD 

This read/write port acts as the floppy disk control track register port and is discribed in 
detail in Appendix F. 

3.2.15 Port OE 

This read/write port acts as the floppy disk control sector register port and is discribed in 
detail in Appendix F. 

3.2.16 Port OF 

This read/write port acts as the floppy disk control data port and is described in detail in 
Appendix F. 

3.2.17 Ports 10-13 

These ports act as direct memory access (DMA) control ports. The Z80A DMA controller 
requires only one control/status port; ports 11, 12, and 13 (hex) are therefore identical to 
port 10 (hex). The floppy disk controller (FDC) data request line is tied to the Z80 DMA 
ready input and is active when the signal is high. The DMA controller can move data to 
and from the FDC and memory, any I/O channel and memory, or memory and memory, on 
or off the board. 

*NOTE: All DMA other than FDC must be 
started by ready = low (e.g., FDC DRQ = low) 
and sycronized using the S-100 wait line, pin 
72. The DMA interrupt output is connected 
to interrupt jumper 36. INT from the DMA is 
active when low. 
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3.2.18 



Port \k 



This read/write port acts as 
identification, and density port. 



the lloppy disk coritroller synchronization, drive 



3.2.18.1 



Port I'f, Write Operation 



The two low-order bits (DO and Dl) specify the disk drive (see table below). Bit D2 
selects the disk head. Bit D3 specifies the disk density, where zero (0) specifies single 
density and 1 specifies double density. Bit D^ specifies the disk drive size, where zero (0) 
specifies 8~inch disk and 1 specifies 5.25-inch disk. 



The bit significance is shown below. 



D7 



D6 



D5 



Df 



D3 



D2 



Dl 



DO 



D7 = MSB; DO = LSB 






Disk drive select (see table below) 
■♦^Disk drive select (see table below) 
■♦"Head select (0=:head 1; l=head 2) 
"♦"Disk Density (0=single; l=double) 
"*^Size select (0=8 inch; 1=5.25 inch) 
■*"Not read 
-*~Not read 
-♦'Not read 



Ihe two low-order bits (DO and Dl) specify the selected disk drive, where: 

Dl DO RESULT 

Disk Drive selected 

1 Disk Drive 1 selected 

1 Disk Drive 2 selected 
1 1 Disk Drive 3 selected 

Two connectors are provided on the SUPER SIX for the floppy disk: Jl and 33. 31 drives 
the 5.25-inch floppy disk; pin 1 is clearly marked to this effect. 03 drives the 8 inch disk. 
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3.2,19 Port 15 

3.2.19.1 Port 15, Read Operation 

This port reads the on-board baud rate. The bit significance is shown below. 

D7 = MSB; DO = LSB 



D7 



D6 



D5 



D^ 



D3 



D2 



Dl 



DO 



™"""^^ 



Switch 1.0 = closed; 1 = open 
.^ Switch 2. = closed; 1 = open 
-)»- Switch 3. = closed; 1 - open 
-«► Switch 'f. = closed; 1 = open 
•*- Switch 5. = closed; 1 = open 
■♦- Switch 6. = closed; 1 = open 
-•- Switch 7.0 = closed; 1 = open 
-»- Double sided disk drive status. 

= double sidee diskette 



Note: Jumper 37 specifies the hardware setting for the 
baud rate. Port 15 reads jumper 37 to determine the 
hardware specified rate. 



Jn 4.a X^ n jL 



Port 15, Write Operation 
This port controls the S-100 extended address lines. The bit significance is shown below: 

D7 = MSB; DO = LSB 



D7 



D6 



D5 



D^t 



D3 



D2 



Dl 



DO 






A16 
^A17 
-•-A18 
-»■ A19 
■*'A20 
-^A21 
-4^A22 
HP-A23 



3.2.20 



Ports 16 and 17 



These write-only ports act as the on-board memory control ports zero (0) and 1 
respectively. These ports control the on-board memory management circuit, PROM 
enable and disable circuit, power-on jump reset circuit, and the parity check enable. Port 
zero (0) controls the first 64k bytes of memory; port 1 controls the second 6^K of memory- 
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3,2.20.1 



Port 16, Write Operation 



The four low-order bits (DO, Dl, D2, and D3) switch the on-board memory ON and OFF in 
16K banks. Relative addresses of these banks are as shown below, (in hex^. 



BANK 


FROM 


TO 


DO 
Dl 
D2 
D3 


0000 
^000 
8000 
COOO 


3FFF 
7FFF 

BFFF 
FFFF 



Bit 5 of this port switches the on-board EPROM ON and OFF. This EPROM occupies 
addresses FOOO through FFFF (Hex). After the operating system is loaded the EPROM can 
be set to OFF to enable accessing of the RAM addresses FOOO through FFFF (hex); it is 
switched to ON Automatically during reset or power-on. This EPROM contains the SIO 
and FDC initialization code, a simple debugger, and the floppy disk cold-start loader. 

Bit D6 resets the power-on jump circuit; it must be reset high before RAM can be 
accessed upon completion of a reset or power-on operation. 

Bit D7 enables and disables the on-board memory parity check latch. On power-up or 
reset, this bit is set to low and disables the parity circuit. Prior to enabling the parity 
circuit, all memory must be written; this initializes the parity bit for each location. If a 
parity error occurs an on-board LED is turned ON. If interrupts are enabled and the board 
is jumpered for parity error interrupts, the location in error can be located by clearing bit 
D7 (to clear the error), resetting the bit, and then reading each location again; If no parity 
error is encountered it is likely that the error encountered was a soft read error. Parity 
error interrupts can be jumpered to create a non-maskable or counter/timer channel 
interrupt. 



The bit significance of this port is shown below. 



D7 


D6 


D5 


D^ 


D3 


D2 


Dl 


DO 












„ , 








, , 1 




LiH 


»>• 
































»•- 























D7 = MSB; DO = LSB 



1 = Bank ON; 
Memory bank 



Bank OFF 

0000 - 3FFF (hex) 

Memory bank 1 = ^fOOO - 7FFF (hex) 

Memory bank 2 = 8000 - BFFF (hex) 

Memory bank 3 = COOO - FFFF (hex) 

Not read 

PROM enabled = 0; PROM disabled = 1 

Power on jump reset = 1 

Parity check enable = 1 
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3.2.20.2 



Port 17, Write Operation 



Bits DO, Dl, D2, and D3 switch the second 64K set oi on-board memory similarly to the 
corresponding bits for port 16. Bits Df, D5, and D6 control memory mapping of the 
second set of memory. The first set of 6^K bytes is not affected by these settings. Five 
memory maps are available and are depicted below. Note that if any 16K segment from 
the first bank is selected to overlay a 16K segment from the second bank, only the first 
bank's 64K memory is selected. 

The bit significance of map is shown below. No overlays may be performed on this bank. 



D7 



D6 



D5 



D«t 



D3 D2 



Dl 



DO 



07 := MSB; DO = LSB 






1 = Bank ON; = Bank OFF 
Memory bank k = 0000 - 3FFF (hex) 

*- Memory bank 5 = 'fOOO - 7FFF (hex) 

•"Memory bank 6 ::: 8000 - BFFF (hex) 

•-Memory bank 7 = COOO - FFFF (hex) 

•-Set to zero for map zero 

•-Set to zero for map zero 

■•-Set to zero for map zero 

•-Not read 



The bit significance of map I is shown below. Bank zero of the first memory set may 
overlay bank 7. 



07 


D6 


D5 


D4 


D3 


D2 


Dl 


DO 






















•► 
















i» 














( 


















, 











D7 = MSB: DO = LSB 



1 = Bank ON; 
Memory bank H- 
Memory bank 5 
Memory bank 6 
Memory bank 7= 



= Bank OFF 
= 0000 - 3FFF (hfex) 
= -ilOOO - 7FFF (hex) 
=: 8000 - BFFF (hex) 
:0000-3FFF(hex)-bank 



Set to I for rnap 1 
Set to zero for map i 
Set to zero for map I 

Not read 



19- 



The bit significance of map 2 is shown below. Bank I oi the first memory set may overlay 
bank 6. 



D7 



D6 



D5 



D^ 



D3 



D2 Dl 



DO 



H 



D7 = MSB; DO = LSB 



I = Bank ON; = Bank OFF 
Memory bank ^f = 0000 - 3FFF (hex) 
Memory bank 5 = ^000 - 7FFF (hex) 
Memory bank 6='f000-7FFF(hex)-bank 1 
Memory bank 7 = COOO - FFFF (hex) 
Set to zero for map 2 
Set to 1 for map 2 
Set to zero for map 2 
Not read 



The bit significance of map 3 is shown below. Banks zero and 1 of the first memory set 
overlay banks 6 and 7, respectively. 



D7 



D6 



D5 



Dif 



D3 



D2 



OI 



DO 



D7 = MSB; DO = LSB 



u 



1 = Bank ON; = Bank OFF 
Memory bank ^ = 0000 - 3FFF (hex) 

•- Memory bank 5 = 4000 - 7FFF (hex) 

•► Memory bank 6=0000-3FFF(hex)-bank 

•-Memory bank 7=4000-7FFF(hex)-bank 1 

■•-Set to I for map 3 

•-.Set to I for map 3 

•-Set to zero for map 3 

-•-Not read 



The bit significance of map 4 is shown below. Bank 3 of the first memory set overlays 
bank 4. 



D7 


D6 


D5 


D'f 


D3 


D2 


Dl 


DO 


























Lan.^ 


•» 





























































D7 = MSB; DO = LSB 

1 := Bank ON; = Bank OFF 
Memory bank /f=COOO-FFFF(hex)-bank 3 
Memory bank 5 = fOOO - 7FFF (hex) 
Memory bank 6 = 8000 - BFFF (hex) 
Memory bank 7 = COOO - FFFF (hex) 
Set to zero for map 4 
Set to zero for map tf. 
•- Set to 1 for map 4 
Not read 
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EXAMPLES OF BANKING: 



64K - Bank 



6 4K - Bank 1 



Bank ~ Controlled by Port 16 

There are five maps possible in Bank 1. 
Bank always overrides. Once a bit in Bank 
is set, you will always get the corresponding 
memory in that Bank only. 

Bank 1 - Port 17, 

Depending on the map used. 



Map - You will get the corresponding memory in Map 0, 
Bank 1 if you don't have the Bank bit set. 



Map 1 ~ If you set bit , then you will get 0-16K, 
if you set just bit 3 , then you get 0-16K 
which corresponds with 48-64K in Map 0. 



MAP 



3/7 


COCO 


2/6 


8000 


1/5 


4000 


0/4 






MAP 1 


3 


2/6 


1/5 


0/4/7 



MAP 2 



3/7 



1/5/6 
0/4 



MAP 3 



1/5/7 




MAP 4 



3/4/7 



2/6 



1/5 



3.2,21 



Port 18 



This write-only port acts as the set-baud-rate port and allows the user to perform a 
software reset of the baud rate for SIO channels A and B. The bit significance of this port 
is shown below. 



D7 



D6 



D5 



D4 



D3 



D2 



Dl 



DO 



D7 = MSB; DO = LSB 



H 



SIO 
"SIO 
-SIO 
-SIO 
-SIO 
"-SIO 
►SIO 
•-SIO 



channel 
channel 
channel 
channel 
channel 
channel 
channel 
channel 



A baud 
A baud 
A baud 
A baud 
B baud 
B baud 
Bbaud 
B baud 



bit A 
bit B 
bit C 
bit D 
bit A 
bit B 
bit C 
bit D 



The baud rates equated with bit settings A, B, C, and D are shown in Table 3-2. 
identical for both channel A and channel B. 



These are 



BIT 


BIT 


BIT 


BIT 


BAUD 


D 


C 


B 


A 


RATE 














50 











1 


15 








1 





110 








1 


1 


13^^.5 





1 








150 





1 





I 


300 





1 


1 





600 





1 


1 


1 


1200 













ISOO 










1 


2000 







1 





2^00 







i 


1 


3600 




1 








^800 




1 





1 


7200 




1 


1 





9600 




1 


1 


1 


19,200 



Table 3-2. SUPER SIX Port 18 Baud Rate Settings 
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SECTION IV 
3UMPER CONNECTIONS 



It A 



JUMPER DEFINITIONS 



Table 'f-l presents the available jumpers and abbreviates their assigned functions. 
Detailed descriptions of individual jumper functions are presented following this table. To 
facilitate jumper insertion, each three (or more) pin jumper is depicted in an illustration 
contained within the narrative for that jumper^ 



JUMPER 



FUNCTION 



A 
B 

C 
D 
E 



G 
H & T 
3 

36 

37 
K 

M 



Generates Wait States 

Selects between on-board Tri-state and S-100 bus buffering 
(MWRITE) 

Selects 6M Hz or ^MHz operation 

Selects 6MHz or 'fMHz operation For DMA ONLY (2^3) 

Selects between the S-100 bus interrupt (INT) and the vectored 
interrupt zero (VIO) 

Used in conjunction with jumpers P, N, M, K, R, S, and 3, this 
jumper area selects between vectored interrupts and the parallel I/O 
second port 

Used in adjusting the floppy disk controller phase line level (PLL) 

This jumper area selects synchronous or asynchronous serial I/O 

Used in conjunction with jumpers P, N, M, K, R, S, and F, this 
jumper area selects between vectored interrupts and the parallel I/O 
second port 

Used for interrupts of the CTC to 1.5 MHz, DMA or parity error, 
NMIor INTRQ 

Used to set the hardware baud rate 

Used in conjunction with jumpers P, N, M, 3, R, S, and F, this 
jumper area selects between vectored interrupts and the parallel I/O 
second port 

Used in conjunction with jumpers P, N, 3, K, R, S, and F, this 
jumper area selects between vectored interrupts and the parallel I/O 
second port 



Table it~l. SUPER SIX 3umpers and Abbreviated Functions 
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3UMPER 



N 



R 

R25 
S 



FUN CI ION 



Used in conjunctiori with jurripers P, M, ], K, R, S, and F, this 
junriper area selects between vectored interrupts and the parallel I/O 
second port 

Used in conjunction with jumpers i\, M, 3, K, R, S, and F, this 
jumper area selects between vectored interrupts and the parallel I/O 
second port 

Used in conjunction with jumpers P, N, M, 3, K, S, and F, this 
jumper area selects between vectored interrupts and the parallel I/O 
second port 

Used to select the 2716 or the 2732 EPROM 

Used in conjunction with jumpers P, N, M, 3, K, R, and F, this 
jumper area selects between vectored interrupts and the parallel I/O 
second port 



4.2 
4,2.1 



Table 4-1. SUPER SIX Jumpers and Abbreviated Functions (Continued) 



JUMPER DESCRIPTIONS 



Jumper A 

This two-pin jumper must be installed when running DMA. 
4.2.2. Jumper B 



B 



1 
2 



When installed this two-pin jumper causes buffering of the M WRITE signal to be 
performed through the on-board tri-state buffer. When not installed, buffering is 
performed through the S-100 bus. In most cases this jumper is installed. 



4.2.3 



Jumper C 



When Installed between 1 and 2, this jumper sets the board for 6MHz operation. When 
installed between 2 and 3, 4MHz operation is specified. Also see jumper D, below. 
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i^oIA 



Jumper D 



When installed between 1 and 2, this jumper sets the board for 6MHz operation. When 
installed between 2 and 3, itMHz operation is specified. Also see jumper C, above, p^j. pj^^ 
Operation plxig between 2-3 always „ 
1^.2,5 Jumper E 



1 



This jumper determines whether the S-100 bus interrupt (INT) or the vectored interrupt 
zero (VIO) is to be used. When installed between pins 1 and 2, the VIO is tied to priority 
interrupt DAISY CHAIN. When installed between pins 2 and 3, the priority interrupt 
(S-100 pin 73) is tied to the interrupt DAISY CHAIN. 



it.2.6 



Dumper G 



This jumper adjusts the floppy disk controller phase-locked loop (PLL) and is not installed 
unless adjusting the PLL. 



iT* iC.» / 



Jumpers H and T 



12 3 

12 3 



H 
T 



This jumper area specifies that serial I/O is to be performed synchronously or 
asynchronously. When installed between pins 1 and 2 of jumpers H and T, synchronous 
operation is selected; when installed between pins 2 and 3, asynchronous operation is 
selected. Pins 1 and 11 of the I't pin J^ and 35 connectors are not factory connected. 
These may be used in synchronous operations to bring the external clock or ring indicator 
into the SIO. 



4.2.8 



Jumper J6 



This jumper is for CTC external interrupts. Pin 14 is the 1.5MHz clock; Pin 12 is 
INTDMA; pin 10 is PERR (parity error); pin 9 is NMI; pin 8 is INTRQ. Jumper J6 internal 
interrupts are 7-6, 5-4, and 3-2. 
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ii.2.9 



Jumper R25 



This jumper alioNx.s selection between Iho 2716 and 2732 EPROMs. When installed 
between pins 1 ana 2, the 2716 tPRO.W is addressed: when installed between pins 2 and 3, 
the 2732 EPROM is addressed. 



4.2.10 



Jumper 37 



GND 
GND 
GND 
GND 
GND 
GND 
GND 



8 


7 


9 


6 


10 


5 


11 


4 


12 


3 


13 


2 


14 


1 



BDo 
BD5 

BD4 
BD3 
BD2 
BDl 

BDO 



This jumper sets the hardware baud rate. When the jumper is inserted an inverted ground 
condition exists (I); when not inserted a zero (0) value is assumed. This setting must agree 
with the Set Baud Rate Port (port 18 - refer to subsection 3.2.21) e.g., when 7, 6, 5, and 4 
are installed, 19.2K baud is read. 



4.2.11 



Jumpers P, N, M, K, J, R, S, and F 

3 2 } 



p 








N 








M 








K 








3 








R 








s 








F 









These jumpers select between vectored interrupts or the Parallel I/O second port. When 
installed between pins 1 and 2, the vectored interrupts zero (0) to 7, as selected, are 
enabled and connected to Parallel I/O port B. When jumpers are installed between pins 2 
and 3, Parallel I/O port B is connected to the 32 connector. 
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4.3 



FACTORY AND OEM INSTALLED JUMPERS 



4.3.1 8-lnch Floppy Disk Drive 

Install jumpers as indicated below. 

3UMPER BETWEEN PINS 



FUNCTION 



B 




C 


1-2 


D 


2-3 


E 


1 - 2 


H 


2-3 


T 


2-3 


36 


1^1 A, 7^8 




^-2 


37 


5, 6, 7, 8 


P 


2-3 


N 


2-3 


M 


2-3 


K 


2-3 


3 


2-3 


R 


2-3 


S 


2-3 


F 


2-3 



Enables the S~100 bus memory 
Set for 6MHz operation 
Set for 4MHZ DMA 
Vectored Interrupt zero 
Specifies asynchronous SIO 
Specifies asynchronous SIO 
Between 1^14 Clock/TRG3 to 
Between 7t^8 Clock/TRG2 to 
Between 2-3: Clock TRGl to 
19.2K baud rate 
Selects parallel port B 
Selects parallel port B 
Selects parallel port B 
Selects parallel port B 
Selects parallel port B 
Selects parallel port B 
Selects parallel port B 



write signal 



Bit DO 
Bit Dl 
Bit D2 
Bit D3 
Bit D4 
Bit D5 
Bit D6 



T02 of the CTC 
TOl of the CTC 
TOO of the CTC 

on 32-25 
on 32-27 

on 32-29 
on 32-31 

on 32-33 
on 32-35 



on 32-37 
Selects parallel port B, Bit D7 on 32-39 



4.3.2 Shugart SA 800/801 Disk Drive 

Remove all factory installed jumpers and install as follows: 



Jumper C 

Jumper T2 

Jumper DSl (Drive Select 1) 

Jumper DS 

Jumper RR 

Jumper 800 

Jumper A 

Jumper B 

Jumper Tl 

Jumper T3, T4, T5, T6, for end of cable 
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1^33 Shugart 850 Disk Drive 

Install the terminator at the cable end. Remove all factory iristalled jumpers ano install 
as follows^ 

Jumper 2S 

Jumper C 

Jumper A 

Jumper b 

Jumper R 

Jumper 1 

Jumper Y 

Jumper 850 

Jumper 52 

Jumper IT 

Jumper FS 

Jumper RM 

Jumper DS 

Jumper S 

Jumper M 

Jumper FM, MFM 

Jumper DSl (for drive 1) 

Jumper DS2 (for drive 2) 

ilf3A MFE Model 700 Disk Drive 

Install jumpers as indicated below; 

Jumper J3 
Jumper RHL 
Jumper J^f 
Jumper L-1 
Jumper J3 
Jumper WPl 
Jumper 3 1 -it, J 1-8 
Jumper JIO 
Jumper 37 
Jumper SSI 
Jumper SE2 
Jumper Jl I, HSl 

^•3.5 Tandon Slim Line Disk Drive 

Install the terminator at the cable end. Install jumpers as indicated below: 

Jumper DSl (for drive 1) 
Jumper DS2 (for drive 2) 



-27- 



4.3.6 NEC Model FDl 160 Disk Drive 

Install jumpers as indicated below: 

Jumper C 
Jumper N 
Jumper HLS 
Jumper M 
Jumper PRl 
Jumper OLD 
Jumper FU 

«f.3.7 QUME Data Track 8 Disk Drive 

Install and cut jumpers as indicated below; 



Jumper DSl (for drive 1) 

Jumper DS2 (for drive 2) 

Jumper Y 

Jumper C 

Cut X 

Cut Z 

Cut L 



4.3.8 Tandon 5.25-inch Disk Drive (48TPI) 

Install jumpers on the DIP shunt as indicated below; 



Jumper pin 7 

Jumper pin 8 

Jumper pin 2 (for drive 1) 

Jumper pin 3 (for drive 2) 



4.3.9 Mitsubishi Model 2894 Disk Drive 

Install and cut jumpers as indicated below: 



Jumper Y 

Jumper E 

Jumper off 

Jumper R 

Jumper DS (drive select) 

Jumper S2 

Jumper D 

Jumper H 

Jumper I 
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*.3.J0 Mitsubishi Model 2896 Disk Drive 

Install jumpers as indicated below: 



Jumper jfg Jumper B 

Jumper ps Jumper RS 

Jumper si next to SE Jumper HUD 

Jumper s2 Jumper Z 

Jumper m Jumper WP 

Jumper c Jumper HY 

Jumper i 

Jumper R 

Jumper it 

Jumper dS (drive select) 

Jumper RFa 

Jumper a 

4.3.1 1 Shugart SA 860 Disk Drive 

Install jumpers as indicated below^ 

Jumper DS 
Jumper S2 
Jumper SR 
Jumper TR 

*f.3.12 Siemens FDD-100~8 Disk Drive 

Install jumpers as indicated below; 

Jumper RR ^""^P^^ ^S 

Jumper U ^"""P^"" ^ND 

Jumper H ^"^P^*" ^E 

Jumper D Jumper Cut Jumper 32 and connect jumper 

Jumper L ' ^^' E 

Jumper 2 for radial step 

Jumper Cut iumner G & connect H 

Jumper ^n 

Note: Jumper H is normally shipped as G. -Jumper is 
set for 8 or 1 6 sectors. 

4.3.13 Qume Irak 592 5.25-inch Disk Drive 

Install jumpers as indicated below: 

Jumper HS 
Jumper DSO 

4.3.14 All Other Disk Drives 

Refer to manufacturer-supplied technical manual for specific drive. 

Note: The last drive at the end of the cable must be 
terminated. 
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SECTION V 
EXTERNAL CONNECTOR PINS 



5,1 



CONNECTORS- 100 



This connector interfaces SUPER SIX to the S-100 bus. Pin numbers and names are shown 
in Table 5-L 



PIN 


NAME 


PIN 


NAME 


PIN 


NAME 


1 


+8V 


25 


PSTVAL* 


58 


SXTRQ* 


2 


+ 16V 


26 


PHLDA 


59 


A19 


3 


XRDY 


27-28 


RFU 


60 


SIXTN* 


4 


VIO* 


29-3^^ 


A5,h,i, 


61-6^ 


A20-A23 


5 


VII* 




15,12,9 


65-66 


NDEF 


6 


VI2* 


35 


DOl/DATAl 


67 


PHANTOM* 


7 


VI3* 


36 


DOO/DATAO 


68 


MRWT 


8 


VW* 


37 


AlO 


69 


RFU 


9 


VI5* 


38 


D04 


70 


GND 


10 


VI6* 


39 


D05 


71 


RFU 


11 


VI7* 


'fO-^3 


D06,12 


72 


RDY 


12 


NMI* 




13,17 


73 


INT* 


13 


PWRFAIL* 


^^ 


SMI 


71- 


HOLD* 


1^ 


DMA3* 


i^5 


SOUT 


75 


RESET* 


15 


A18 


t^e 


SINP 


76 


PSYNCH 


16 


A17 


hi 


SMEMR 


77 


PWR* 


17 


A16 


k% 


SHLTA 


78 


PDBIN 


18 


SDSB* 


h9 


CLOCK 


79-87 


AO-All 


19 


CDSB* 


50 


GND 


88-95 


DO2-DI0 


20 


GND 


51 


+8V 


96 


SINTA 


21 


NDEF 


52 


-16V 


97 


SWO* 


22 


ADSB* 


53 


GND 


98 


ERROR* 


23 


DODSB* 


5h 


SLAVE CLR* 


99 


POC* 


2^ 





55-57 


DMA0*-DMA2* 


100 


GND 



Table 5-1. S-100 Connector Pins and Pin Functions 
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^a/C 



CONNECTOR 32 



This connector interfaces the SUPER SIX to the parallel port. Pin numbers, names, and 
functions are shown in Table 5-2. 



PIN 


NAME 


FUNCTION 


1 


ARDY 


PIO Channel A Ready Signal 


2 


ARDY RET 


Ground 


3 


ASTRB* 


PIO Channel A Strobe 


t^ 


ASTRB RET 


Ground 


5 


PAO 


PIO Channel A Data Bit 


6 


PAORET 


Ground 


7 


PAl 


PIO Channel A Data Bit 1 


8 


PAl RET 


Ground 


9- 


PA2 


PIO Channel A Data Bit 2 


10 


PA2RET 


Ground 


U 


PA3 


PIO Channel A Data Bit 3 


12 


PA3RET 


Ground 


13 


PA4 


PIO Channel A Data Bit 4 


14 


PA4 RET 


Ground 


15 


PA5 


PIO Channel A Data Bit 5 


16 


PA5RET 


Ground 


17 


PA6 


PIO Channel A Data Bit 6 


18 


PA6RET 


Ground 


19 


PA 7 


PIO Channel A Data Bit 7 


20 


PA7 REl 


Ground 


21 


BRDY 


PIO Channel B Ready Signal 


22 


BRDY RET 


Ground 


23 


BSTRB* 


PIO Channel B Strobe 


m- 


BSTRB RET 


Ground 


25* 


PBO 


PIO Channel B Data Bit 


26 


PBO RET 


Ground 


27* 


PBl 


PIO Channel B Data Bit 1 


28 


PBl RET 


Ground 


29* 


PB2 


PIO Channel B Data Bit 2 


30 


PB2 RET 


Ground 


31* 


PB3 


PIO Channel B Data Bit 3 


32 


PB3 RET 


Ground 


33* 


PB4 


PIO Channel B Data Bit 4 


34 


PB4 RET 


Ground 


35* 


PB5 


PIO Channel B Data Bit 5 


36 


PB5 RET 


Ground 


37* 


PB6 


PIO Channel B Data Bit 6 


38 


PB6 RET 


Ground 


39* 


PB7 


PIO Channel B Data Bit 7 


40 


+5 Volts 





* ~ Can be jumpered to the S-100 Bus. 

Table 5-2. SUPER SIX 32 Connector Pin Functions 
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5.3 



CONNECTOR 33 



This connector interfaces the SUPER SIX to the lloppy disk controller, 
functions are shown in Table 5-3- 



Pin numbers and 



8 INCH DISK 


5.25 INCH DISK 


FUNCTION 


PIN 


PIN 




1 




Ground 


2 




Alternate Head 2* 


3 




Ground 


k 




N/C 


5 




Ground 


6 




N/C 


7 




Ground 


8 




N/C 


9 




Ground 


10 




N/C 


11 




Ground 


12 




N/C 


13 




Ground 


1*^ 




Head 2* 


15 




Ground 


16 




N/C 


17 


1 


Ground 


18 




Head Load* 


19 


3 


Ground 


20 


8 


Index* 


21 


5 


Ground 


22 




Ready* 


23 


7 


Ground 


2^ 


8 


Above Track 43* 


25 


9 


ground 


26 


10 


Drive Select 0* 


27 


11 


Ground 


28 


12 


Drive Select 1* 


29 


13 


Ground 


30 


14 


Drive Select 2* 


31 


{5 


Ground 


32 


6 


Drive Select 3* 


33 


17 


Ground 


3t 


18 


Direction 


35 


19 


Ground 


36 


20 


Step* 


37 


21 


Ground 


38 


22 


Write Data* 


39 


23 


Ground 


W 


24 


Write Gate* 


41 


25 


Ground 


itl 


26 


Track 0* 


it3 


; ■ 27 


Ground 


HH 


28 


Write Protect* 


k5 


29 


Ground 


46 


30 


Read Data* 


47 


31 


Ground 


48 


16 


Motor ON* 


49 


33 


Ground 


50 


34 


N/C 


Table 


5-3. SUPER SIX T. 


Connector Pin Functions 
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5 A 



CONNECTOR a^t 



This connector interfaces the SUPER SIX to the 
names, and functions are shown in Table 5-^. 



serial port, channel A. Pin numbers, 



PIN 


NAME 


FUNCTION 


1 


N/C 




2 


DCDA* 


Data Carrier Detect, Channel A* 


3 


5YNCA* 


Sync Detect 


^ 


RxDA 


Receive data 


5 


CTSA* 


Clear To Send 


6 


TxDA 


Transmit Data 


7 


RTSA* 


Request To Send 


8 


DTRA* 


Data Terminal Ready 


9 


Tx/RxCA* 


Transmit/receive Clock 


10 


GND 


Ground 


11 


N/C 




12 


+ 16 Volts 




13 


-16 Volts 




1^ 


+5 Volts 





5.5 



Table 5-4. SUPER SIX 34 Connector Pin Functions 
CONNECTOR 35 



This connector interfaces the SUPER SIX with serial port channel B. Pin numbers, names, 
and functions are shown in Table 5-5. 



PIN 


NAME 


FUNCTION 


1 


N/C 




2 


DCDA* 


Data Carrier Detect, Channel A* 


3 


SYNCA* 


Sync Detect 


4 


RxDA 


Receive data 


5 


CTSA* 


Clear To Send 


6 


TxDA 


Transmit Data 


7 


RTSA* 


Request To Send 


8 


DTRA* 


Data Terminal Ready 


9 


Tx/RxCA* 


Transmit/receive Clock 


10 


GND 


Ground 


11 


N/C 




12 


+16 Volts 




13 


-16 Volts 




14 


+5 Volts 





Table 5-5. SUPER SIX 35 Connector Pin Functions 
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APPENDIX A • 

Z.80A/Z80B SERIAL INPUT/OUTPUT (SIO) AND 
DUAL ASYNCHRONOUS RECEIVER/TRANSMITTER (DART) 



Z8470Z8rDJIBT 
Dual JUymchtmioiii 
B«c«lver/Vraiisiiilttor 



Zitog 



Prodnct 
Speciflcatloii 



March 1981 



Faotur** ■ Two independent full-duplex channels with 

separate modem controls. Modem status can 
be monitored. 

■ Receiver data registers are quadruply buf- 
fered; the transmitter is doubly buffered. 

■ Interrupt features include a programmable 
interrupt vector, a "status affects vector" 
mode for fast interrupt processing, and the 
standard Z-80 peripheral daisy-chain inter- 
rupt structure that provides automatic inter- 
rupt vectoring with no external logic. 



In xl clock mode, data rates are to 500K 
bits/second with a 2.5 MHz clock, or to 
800K bits/second with a 4.0 MHz clock. 

Programmable options include 1 , 1 '/j or 2 
stop bits; even, odd or no parity; and xl, 
xl6, x32 and x64 clock modes. 

Break generation and detection as well as 
parity-, overrun- and framing-error detec- 
tion are available. 



CI 

s 



DMcrlptlon The Z-80 DART (Dual-Channel Asynchro- 

nous Receiver/Transmitter) is a dual-channel 
multi-function peripheral component that 
satisfies a wide variety of asynchronous serial 
data communications requirements in micro- 
computer systems. The Z-80 DART is used as a 
serial-to-parallel, parallel-to- serial converter/ 
controller in asynchronous applications. In 
addition, the device also provides modem con- 
trols for both channels. In applications where 



modem controls are not needed, these lines 
can be used for general-purpose I/O. 

Zilog also offers the Z-80 SIO, a more ver- 
satile device that provides synchronous 
(Bisyno, HDLC and SDLC) as well as asyn- 
chronous operation. 

The Z-80 DART is fabricated with ri-channel 
silicon-gate depletion- load technology, and is 
packaged in a 40-pin plastic or ceramic DIP. 
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Pla B/A. Channel A Or B Select (input, High 

DeaaripUom selects Channel B). This input defines which 
channel is accessed during a data transfer be- 
tween the CPU and the Z-80 DART. 

C/D. Control Or Data Select (input, High 
selects Control). This input specifies the type 
of information (control or data) transferred on 
the data bus between the CPU and the Z-80 
DART. 

CE. Chip Enable (input, active Low). A Low at 
this input enables the Z-80 DART to accept 
command or data input from the CPU during a 
write cycle, or to transmit data to the CPU 
during a read cycle. 

CLK. System Clock (input). The Z-80 DART 
uses the standard Z-80 single-phase system 
clock to synchronize internal signals. 

CTSA. CTSB. Clear To Send (inputs, active 
Low). When programmed as Auto Enables, a 
Low on these inputs enables the respective 
transmitter. If not programmed as Auto 
Enables, these inputs may be programmed as 
general-purpose inputs. Both inputs are 
Schmitt-trigger buffered to accommodate slow- 
risetime signals. 

Dg-D7. System Data Bus (bidirectional, 

3- state) transfers data and commands between 

the CPU and the Z-80 DART. 



as an interrupt acknowledge if the Z-80 DART 
is the highest priority device that has inter- 
rupted the Z-80 CPU. 



DCDA, DCDB. Data Carrier Detect (inputs, 
active Low). These pins function as receiver 
enables if the Z-80 DART is programmed for 
Auto Enables; otherwise they may be used as 
general-purpose input pins. Both pins are 
Schmitt-trigger buffered. 



DTRA. DTRB. Data Terminal Beady (outputs, 
active Low). These outputs follow the state pro- 
grammed into the DTR bit. They can also be 
programmed as general-purpose outputs. 

lEI. Interrupt Enable In (input, active High) is 
used with lEO to form a priority daisy chain 
when there is more than one interrupt-driven 
device. A High on this line indicates that no 
other device of higher priority is being ser- 
viced by a CPU interrupt service routine. 

lEO. Interrupt Enable Out (output, active 
High). lEO is High only if lEI is High and the 
CPU is not servicing an interrupt from this 
Z-80 DART. Thus, this signal blocks lower 
priority devices from interrupting while a 
higher priority device is being serviced by its 
CPU interrupt service routine. 

INT. Interrupt Request (output, open drain, 
active Low). When the Z-80 DART is re- 
questing an interrupt, it pulls INT Low. 

ML Machine Cycle One (input f rom Z-80 
CPU, active Low). When Ml and RD are both 
active, the Z-80 CPU is fetching an inst ructio n 
from memory; when Ml is active while lORQ is 
active, the Z-80 DART accepts Ml and lORQ 



lORQ. Input /Outp ut Bequest (input from CPU, 
active Low). lORQ is used in conjunction with 
B/A, C/D, CE and RD to transfer commands 
and data between the CPU and the Z-80 
DART. When CE, RD and lORQ a£e all 
active, the channel selected by B/A transfers 
data to the CPU (a read operation). When CE 
and lORQ are active, but RD is inactive, the 
channel selected by B/A is written to by the 
CPU with either_data or control information as 
specified by C/D. 

RxCA. RxCB. Beceiver Clocks (inputs). 
Rece ive data is sampled on the rising edge of 
RxC. The Receive Clocks may be 1, 16, 32 or 
64 times the data rate. 

RD. Bead Cycle Status, (input from CPU, ac- 
tive Low). If RD is active, a memory or I/O 
read operation is in progress. 

RxDA, RxDB. Beceive Data (inputs, active 
High). 



RESET. Beset (input, active Low). Disables 
both receivers and transmitters, forces TxDA 
and TxDB marking, forces the modem controls 
High and disables all interrupts. 

RIA. RIB. Bing Indicator (inputs . Ac tive 
Low) . These inputs are similar to CTS and 
DCD. The Z-80 DART detects both logic level 
transitions and interrupts the CPU. When not 
used in switched-line applications, thesfe inputs 
can be used as general-purpose inputs. 



RTSA. RTSB. Bequest to Send (outputs, 

active Low) . When the RTS bit is set, the RTS 
output goes Low. When the RTS bit is reset, 
the output goes High after the transmitter 
empties. 



TxCA, TxCB. Transmitter Clo cks (i nputs). TxD 
changes on the falling edge of TxC. The 
Transmitter Clocks may be 1, 16, 32 or 64 
times the data rate; however, the clock 
multiplier for the transmitter and the receiver 
must be the same. The Transmit Clock inputs 
are Schmitt-ti-igger buffered. Both the Receiver 
and Transmitter Clocks may be driven by the 
Z-80 CTC Counter Time Circuit for program- 
mable baud rate generation. 

TxDA. TxDB. Transmit Data (outputs, active 
High). 



W/RDYA, W/RDYB. Wait/Ready (outputs, 
open drain when programmed for Wait func- 
tion, driven High and Low when programmed 
for Ready function). These dual-purpose out- 
puts may be programmed as Ready lines for a 
DMA controller or as Wait lines that syn- 
chronize the CPU to the Z-80 DART data rate. 
The reset state is open drain. 



FuncHoaoJ The iunctional capabilities of the Z-SO DART 

DMKxiptlon can be described from two diHerent point* d 
view: as a data communications device, it 
transmits and receives serial data, and meets 
the requirements of asynchronous data com- 
munications protocols; as a Z-80 family 
peripheral, it interacts with the Z-80 CPU and 
other Z-80 peripheral circuits, and shares the 
data, address and control buses, as well as 
being a part of the Z-80 interrupt structure. As 
a peripheral to other microprocessors, the Z-80 
DART offers valuable features such as non- 
vectored interrupts, polling and simple hand- 



shake capability. 

The first part of the following functional 
description introduces Z-80 DART data com- 
munications capabihties; the second part 
describes the interaction between the CPU and 
the Z-80 DART. 

A more detailed explanation of Z-80 DART 
operation can be found in the Z-80 SIO Tech- 
nical Manual (Document Number 03-3033-01). 
Because this manual was written for the 
Z-80 SIO, it contains information about syn- 
chronous as well as asynchronous operation. 



Communications Capabilities. The Z-80 
DART provides two independent full-duplex 
channels for use as an asynchronous 
receiver/transmitter. The following is a short 
description of receiver/transmitter capabilities. 
For more details, refer to the Asynchronous 
Mode section of the Z-80 SIO Technical 
Manual. The Z-80 DART offers transmission 
and reception of five to eight bits per 
charactei , plus optional even or odd parity. 
The transmitter can supply one, one and a half 
or two stop bits per character and can provide 
. a break output at any time. The receiver break 
detection logic interrupts the CPU both at the 
start and end of a received break. Reception is 
protected from spikes by a transient spike re- 
jection mechanism that checks fhe signal one- 
half a bit time after a Low level is detected on 
the Receive Data, input. If the Low does not 
persist — as in the case of a transient — the 
character assembly process is not started. 



Framing errors and overrun errors are 
detected and buffered together with the 
character on which they occurred. Vectored 
ihterrupts allow fast servicing of interrupting 
conditions using dedicated routines. Further- 
more, a built-in checking process avoids inter- 
pret!! r- I framing error as a new start bit; a 
fram ■ or results in the addition of one-half 

a bit time to the point at which the search for 
the next start bit is begun. 

The Z-80 DART does not require symmetric 
Transmit and Receive Clock signals — a feature 
that allows it to be used with a Z-80 CTC or 
any other clock source. The transmitter and 
receiver can handle data at a rate of 1, 1/16, 
1/32 or 1/64 of the clock rate supplied to the 
Receive and Transmit Clock inputs. When 
using Channel B, the bit rates for transmit and 
rece ive operations must be the sam e because 
RxC and TxC are bonded t<3!;jether (RxTxCB). 



e 



I/O Intarlace Capabilities. The Z-80 DART 
offers the choice of Polling, Interrupt (vectored 
or non- vectored) and Block Transfer modes to 
transfer data, status and control information to 



and from the CPU. The Block Transfer mode 
can be implemented under CPU or DMA 
control. 
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Functional POLLING. There are no interrupts in the 

Description Polled mode. Status registers RRO and RRl are 
(Continued) updated at appropriate times for each function 
being performed. All the interrupt modes of 
the Z-80 DART must be disabled to operate the 
device in a polled environment. 

While in its Polling sequence, the CPU 
-examines the status contained in RRO for each 
channel; the RRO status bits serve as an 
acknowledge to the Poll inquiry. The two RRO 



status bits Dq and D2 Indicate that a data 
transfer is needed. The status also indicates 
Error or other special status conditions (s^ 
"Z-80 DART Programming"). The Special 
Receive Condition status contained in RRl 
does not have to be read in a Polling sequence 
because the status bits in RRl are accom- 
panied by a Receive Character Available 
status in RRO. 



INTERRUPTS. The Z-80 DART offers an 
elaborate interrupt scheme that provides fast 
interrupt response in real-time applications. As 
a member of the Z-80 family, the Z-80 DART 
can be daisy- chained along with other Z-80 
peripherals for peripheral interrupt-priority 
resolution. In addition, the internal interrupts 
of the Z-80 DART are nested to prioritize the 
various interrupts generated by Channels A 
and B. Channel ,B registers WR2 and RR2 con- 
tain the interrupt vector that points to an inter- 
rupt service routine in the memory. To 
eliminate the necessity of writing a status 
analysis routine, the Z-80 DART can modify the 
interrupt vector in RR2 so it points directly to 
one of eight interrupt service routines. This is 
done under program control by setting a pro- 
gram bit (WRl, D2) in Channel B called 
"Status Affects Vector." When this bit is set, 
the interrupt vector in RR2 is modified accord- 
ing to the assigned priority of the various 
interrupting conditions. 

Transmit interrupts, Receive interrupts and 
External/Status interrupts are the main sources 
of interrupts. Each interrupt source is enabled 
under program control with Channel A having 
a higher priority than Channel B, and with 
Receiver, Transmit and External/Status inter- 
rupts prioritized in that order within each 
channel. When the Transmit interrupt is 
enabled, the CPU is interrupted by the 
transmit buffer becoming empty. (This implies 
that the transmitter must have had a data 
character written into it so it can become 



empty.) When enabled, the receiver can inter- 
rupt the CPU in one of three ways: 

■ Interrupt on the first received character 

■ Interrupt on all received characters 

■ Interrupt on a Special Receive condition 

Interrupt On First Character is typically 
used with the Block Transfer mode. Interrupt 
On All Receive Characters can optionally 
modify the interrupt vector in the event of 
a parity error. The Special Receive Condition 
interrupt can occur on a character basis. The 
Special Receive condition can cause an inter- 
rupt only if the Interrupt On First Receive 
Character or Interrupt On All Receive Char- 
acters mode is selected. In Interrupt On First 
Receive Character, an interrupt can occur 
from Special Receive conditions (except Parity 
Error) after the first receive character interrupt 
(example: Receive Overrun interrupt). 

The main function of the External/Status 
inte rrupt i s to m onitor the signal transitions of 
the CTS , DCD and RI pins; however, an 
External/Status interrupt is also caused by the 
detection of a Break sequence in the data 
stream. The interrupt caused by the Break 
sequence has a special feature that allows the 
Z-80 DART to interrupt when the Break 
sequence is detected or terminated. This 
feature facilitates the proper termination of the 
current message, correct initialization of the 
next message, and the accurate timing of the 
Break condition. 



CPU/DMA BLOCK TRANSFER. The Z-80 
DART provides a Block Transfer mode to 
accommodate CPU block transfer functions 
and DMA block transfers (Z-80 DMA or other 
designs). The Block Transfer mode uses the 
W/RDY output in conjunction with the 
Wait/Re ady bits of Write Register 1 . The 
W/RDY output can be defined under software 
control as a Wait line in the CPU Block 



Transfer mode or as a Ready line in the DMA 
Block Transfer mode. 

To a DMA controller, the Z-80 DART Ready 
output indicates that the Z-80 DART is ready to 
transfer data to or from memory. To the CPU, 
the Wait output indicates that the Z-80 DART is 
not ready to transfer data, thereby requesting 
the CPU to extend the I/O cycle. 



Intanuxl' The device internal structure includes a Z-80 

Jkrchit*ctuir« CPU interface, internal control and interrupt 
logic, and two full-duplex channels. Each 
channel contains read and write registers, and 
discrete control and status logic that provides 
the interface to modems or other external 
devices. 

The read and write register group includes 
five 8-bit control registers and two status 
registers. The interrupt vector is written into 
an additional 8-bit register (Write Register 2) 
in Channel B that may be read through Read 
Register 2 in Channel B. The registers for both 
channels are designated as follows: 

WR0-WR5 — Write Registers through 5 
RR0-RR2 — Read Registers through 2 

The bit assignment and functional grouping 
of each register is configured to simplify and 



organize the programming process. 

The logic for both channels provides for- 
mats, bit synchronization and validation for 
data transferred to and from the channel inter- 
face^ The modem control inp uts C lear to Send 
(CTS); Data_Carrier Detect (DCD) and Ring 
Indicator (RI ) are monitored by the control 
logic under program control. All the modem 
control signals are general purpose in nature 
and can be used for functions other than 
modem control. 

For automatic interrupt vectoring, the inter- 
rupt control logic determines which channel 
and which device within the channel has the 
highest priority. Priority is fixed with Channel 
A assigned a higher priority than Channel B; 
Receive, Transmit and External/Status inter- 
rupts are prioritized in that order within each 
channel. 



Data Path. The transmit and receive data path 
illustrated for Channel A in Figure 4 is iden- 
tical for both channels. The receiver has three 
8-bit buffer registers in a FIFO arrangement in 
addition to the 8-bit receive shift register. This 
scheme creates additional time for the CPU to 



service a Receive Character Available inter- 
rupt in a high-speed data transfer. 

The transmitter has an 8- bit transmit data 
register that is loaded from the internal data 
bus, and a 9-bit transmit shift register that is 
loaded from the transmit data register. 
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R«ad Cycl*. The timing signals generated by 
a Z-80 CPU input instruction to read a Data or 



Status byte from the Z-80 DART are illustrated 
in Figure 5a. 



Writ* Cycle. Figure 5b illustrates the timing 
and data signals generated by a Z-80 CPU out- 



put instruction to write a Data or Control byte 
into the Z-80 DART. 



Intanupt Acknowl«dg« Cycle. Afte r receiv- 
ing an Interrupt Reguest signal (INT pulled 
Low), the Z-80 CPU sends an Interr upt 
Acknowledge signal (Ml and lORQ both Low). 
The daisy-chained interrupt circuits determine 
the highest priority interrupt requestor. The lEI 
of the highest priority peripheral is terminated 
High. For any peripheral that has no interrupt 
pending or under service, IEO = IEI. Any 
peripheral that does have an interrupt pending 
or under service forces its lEO Low. 



To insure stable conditions in the daisy 
chain, all interrupt status signals are pr evente d 
from changing while Ml is Low. When lORQ is 
Low, the highest priority interrupt reguestor 
(the one with lEI High) places its interrupt vec- 
tor on the data bus and sets its internal 
interrupt-under-service latch. 

Refer to the Z-80 SIO Technical Manual ior 
additional details on the interrupt daisy chain 
and interrupt nesting. 



Return From Interrupt Cycle. Normally, the 
Z-80 CPU issues an RETI (Return From Inter- 
rupt) instruction at the end of an interrupt ser- 
vice routine. RETI is a 2-byte opcode (ED-4D) 
that resets the interrupt-under-service latch to 
terminate the interrupt that has just been 
processed. 



When used with other CPUs, the Z-80 DART 
allows the user to return from the interrupt 
cycle with a special command called "Return 
From Interrupt" in Write Register of Channel 
A. This command is interpreted by the Z-80 
DART in exactly the same way it would inter- 
pret an RETI command on the data bus. 
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Flgur* 5b. Writ* Cycl* 
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Z-80 DART To program the Z-80 DART, the system pro- 

Prograxaming gram first issues a series of commands that 

initialize the basic mode and then other com- 
mands that quahfy conditions within the select- 
ed mode. For example, the character length, 
clock rate, number of stop bits, even or odd 
parity are first set, then the Interrupt mode 
and, finally, receiver or transmitter enable. 



Both channels contain command registers 
that must be programmed via the system pro- 
gram prior to operation. The Channel Select 
input (B/A) and the Control/Data input (C/D) 
are the command structure addressing con- 
trols, and are normally controlled by the CPU 
address bus. 



Write Regigters. The Z-80 DART contains six 
registers (WR0-WR5) in each channel that are 
programmed separately by the system program 
to configure the functional personality of the 
channels (Figure 4). With the exception of 
WRO, programming the write registers requires 
two bytes. The first byte contains three bits 
(Dq-Dj) that point to the selected register; the 
second byte is the actual control word that is 
written into the register to configure the Z-80 
DART. 

WRO is a special case in that all the basic 
commands (CMDg-CMD2) can be accessed 
with a single byte. Reset (internal or external) 
initializes the pointer bits D0-D2 to point to 
WRO. This means that a register cannot be 



pointed to in the same operation as a channel 
reset. 

Writ* Rogistar Functions 

WRO Register pointers, initialization commands for 
the various modes, etc. 

WR 1 Transmit/Receive interrupt and data transfer 
mode definition. 

WR2 Interrupt vector (Channel B only) 

WR3 Receive parameters and control 

WR4 Transmit/Receive miscellaneous parameters 
and modes 

WR5 Transmit parameters and controls 



Read Registers. The Z-80 DART contains 
three registers (RR0-RR2) that can be read to 
obtain the status information for each channel 
(except for RR2, which applies to Channel B 
only). The status information includes error 
conditions, interrupt vector and standard 
communications- interface signals. 

To read the contents of a selected read 
register other than RRO, the system program 
must first write the pointer byte to WRO in 
exactly the same way as a write register opera- 
tion. Then, by executing an input instruction, 
the contents of the addressed read register can 
be read by the CPU. 



The status bits of RRO and RRl are carefully 
grouped to simplify status monitoring. For 
example, when the interrupt vector indicates 
that a Special Receive Condition interrupt has 
occurred, all the appropriate error bits can be 
read from a single register (RR 1 ) . 

Read Register Functions 

RRO Transmit/Receive buffer status, interrupt 
status and external status 

RRl Special Receive Condition status 

RR2 Modified interrupt vector (Channel B only) 



Z-80 DART 
Read and Write 
Registers 
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WRITE REGISTER 



WRITE REGISTER 1 



REGISTER 
REGISTER 1 
REOISTER a 
REGISTER 3 

REGISTER 4 
REGISTER S 



NULL CODE 
NOT USED 

RESET EXT/STATUS INTERRUPTS 
CHANNEL RESET 

ENABLE INT ON NEXT Rx CHARACTER 
RESET TxINT PENDING 
ERROR RESET 

RETURN FROM INTfCHA ONLY] 
- NOT USED 
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EXT INT ENABLE 
Tn INT ENABLE 
STATUS AFFECTS VECTOR 
(CH. B ONLY) 



Rx INT DISABLE \ 

Rx INT ON FIRST CHARACTER OR ON 

(NT ON ALL Rx CHARACTERS (PARITY I SPECIAL 

AFFECTS VECTOR) f RECEIVE 

INT ON ALL Rx CHARACTERS (PARITY CONDITION 

DOES NOT AFFECT VECTOR) J 

- WAIT/READY ON RfT 

- WAITfREADY FUNCTION 

- WAIT/READY ENABLE 
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1 STOP aiTfCHARACTER 
1 V, STOP BITS/CHARACTER 
a STOP BITS/CHARACTER 



WRITE REGISTER 5 



- NOT USED 

XI CLOCK MODE 
Xie CLOCK MODE 
X32 CLOCK MODE 
XM CLOCK MODE 
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Tn ENABLE 

SEND BREAK 
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APPENDIX B 
Z80A/Z&0B PARALLEL INPUT/OUTPUT (PIO) 



Z8420 

Z80* PIO ParaUel 

Inpat/Ontpiit Controller 



1 



Prodnct 
Specificatloii 



March 1981 



Faattnes B Provides a direct interface between Z-80 

microcomputer systems _flnd peripheral 
devices. 

■ Both ports have interri^t-dri'seii iundMbak^ 

for fast response. 

■ Four programmable opePatimg modes: bj^e 
input, byte output, byte «ipn^o«rtpjjt (Bert A 
only), and bit input/output. 



Programmable interrupts on peripheral 
status conditions. 

Standard Z-80 Family bus-request and 
prioritized interrupt-request daisy chains 
irrr'' '^sented v/ithout external logic. 

The eight Port B outputs can drive Dar- 
lington transistors (1.5 mA at 1.5 V). 



3 



GaiMral The Z-80 PIO Parallel MCS-Circwit is a pro- 

DescaripUon grammable, dual-port <texioe-lhat pfowides a 
TTL-compatible intertaDetetweeni paiptemt 
- devices and the Z-80 CPU« The CSTO oorfigr 
ures the Z-80 PIO to ianrteriace^wlth-e ««ttte 
range of peripheral devices sclSh SO «SbBt. 
external logic. Typical peripheral dewoe* ftiat 
are compatible with the Z-8D PIO iacfed&JMDi^ 
keyboards, paper tape readew arad panefeeBi 
printers, PROM programniess, flic. 

One characteristic of the Z^O pet^janal 
controllers that separates, them ittsm dher 
interface controllers is that all data fransfeK. 
between the peripheral de»ce and the CPU is 
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accomplished under interrupt control. Thus, 
the interrupt logic of the PIO permits full use 
of the efficient interrupt capabilities of the 
JZ-80 CPU during I/O transfers. AH logic 
necessary to implement a fully nested interrupt 
tstructure is included in the PIO. 

Another feature of the PIO is the ability to 
interrupt the CPU upon occurrence of speci- 
died status conditions in the peripheral device. 
iFor example, the PIO can be programmed to 
interrupt if any specified peripheral alarm con- 
jditions should occur. This interrupt capability 
^reduces the time the processor must spend in 
^lolling peripheral status. 
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G«neTal The Z-80 PIO interfaces to peripherals via 

DMcription two independent general-purpose I/O ports, 
(Continued) designated Port A and Port B. Each port has 
eight data bits and two handshake signals, 
Ready and Strobe, which control data transler. 
The Ready output indicates to the peripheral 
that the port is ready for a data transfer. 
Strobe is an input from the peripheral that 
indicates when a data transfer has occurred. 

OptNToting ModM. The Z-80 PIO ports can be 
programmed to operate in four modes; byte 
output (Mode 0), byte input (Mode 1), byte 
input/output (Mode 2) and bit input/output 
(Mode 3). 

In Mode 0, either Port A or Port B can be 
programmed to output data. Both ports have 
output registers that are individually addressed 
by the CPU; data can be written to either port 
at any time. When data is written to a port, an 
active Ready output indicates to the external 
device that data is available at the associated 
port and is ready for transfer to the external 
device. After the data transfer, the external 
device responds with an active Strobe input, 
which generates an interrupt, if enabled. 

In Mode 1 , either Port A or Port B can tie 
configured in the input mode. Each port has 
an input register addressed by the CPU. When 
the CPU reads data from a port, the PIO sets 
the Ready signal, which is detected by the 
external device. The external device then 
places data on the I/O lines and strobes the 
I/O port, which latches the data into the Port 
Input Register, resets Ready, and triggers the 
Interrupt Request, if enabled. The CPU can 
read the input data at any time, which again 
sets Ready. 

Mode 2 is bidirectional and uses Port A, 
plus the interrupts and handshake signals from 
both ports. Port B must be set to Mode 3 and 
masked off. In operation. Port A is used for 
both data input and output. Output operation 
is similar to Mode except that da ta is a llowed 
out onto the Port A bus only when ASTB is 
Low. For input, operation is similar to Mode 1, 
except that the data input uses the Port B 
handshake signals and the Port B interrupt (if 
enabled) . 

Both ports can be used in Mode 3. In this 
mode, the individual bits are defined as either 
input or output bits. This~ provides up to eight 
separate, individually defined bits for each 
port. During operation. Ready and Strobe are 



not used. Instead, ar, inKirrup' ir, ■venerated if 
the condition oi or,«: ir.frjt chan^jes, or if all 
inputs change. The r^n jir<.-ments for gener- 
ating an interrupt ari^ iefined during the pro- 
gramming operation; 'he active level is 
specified as either High or Low, and the logic 
condition is specified as either one input active 
(OR) or all inputs active (AND). For example, 
if the port is programmed for active Low 
inputs and the logic function is AND, then all 
inputs at the specified port must go Low to 
generate an interrupt. 

Data outputs are controlled by the CPU and 
can be written or changed at any time. 

■ Individual bits can be masked off. 

■ The handshake signals are not used in 
Mode 3; Ready is held Low, and Strobe is 
disabled. 

■ When using the Z-80 PIO interrupts, the 
Z-80 CPU interrupt mode must be set to 
Mode 2. 




Figure 3. PIO in a Tfptcol 90 FamUy EnvlnMunMBl 



Intamol The internal structure o< the Z-80 PIO con- 

SlTuctiu* sists of a Z-80 CPU bus interface, internal con- 

trol logic, Port A I/O logic. Port B I/O logic, 
and interrupt control logic (Figure 4). The 
CPU bus interface logic allows the Z-80 PIO to 
interface directly to the Z-80 CPU with no 
other external logic. The interrtBl control logic 
synchronizes the CPU data bus to the per- 
ipheral device interfaces (Port A and Port B). 
The two I/O ports (A and B) are virtually 
identical and are used to interface directly to 
peripheral devices. 

Port Logic. Each port contains separate input 
and output registers, handshake control logic, 
and the control registers shown in Figure 5. 
All data transfers between the peripheral unit 
and the CPU use the data input and output 
registers. The handshake logic associated with 
each port controls the data transfers through 
the input and the output registers. The mode 
control register (two bits) selects one of the 
four programmable operating modes. 

The control mode (Mode 3) uses the remain- 
ing registers. The input/output control register 
specifies which of the eight data bits in the 
port are to be outputs and enables these bits; 
the t^ri^ning bits are inputs. The mask reg- 
ister atnd the mask control register control 
Ma3e.3> interrupt conditions. The mask register 
specifies iwhich of the bits in the port are 
actlwfe -and which are masked or inactive. 



The mask control register specifies two 
conditions: first, whether the active state of 
the input bits is High or Low, and second, 
whether an interrupt is generated when any 
one unmasked input bit is active (OR condi- 
tion) or if the interrupt is generated when 
all unmasked input bits are active (AND 
condition) . 

Intatmpt Control Logic. The interrupt control 
logic section handles all CPU interrupt pro- 
tocol for nested-priority interrupt structures. 
Any device's physical location in a daisy-chain--! 
configuration determines its priority. Two lines 
(lEI and lEO) are provided in each PIO to 
form this daisy chain. The device closest to the 
CPU has the highest priority. Within a PIG,' 
Port A interrupts have higher priority than 
those of Port B. In the byte input, byte output, 
or bidirectional modes, an interrupt can be 
generated whenever the peripheral requests a 
new byte transfer. In the bit control mode, an 
interrupt can be generated when the periph- 
eral status matches a programmed value. The 
PIO provides for complete control of nested 
Interrupts. That is, lower priority devices may 
not interrupt higher priority devices that have 
not had their interrupt service routines com- 
pleted by the CPU. Higher priority devices 
may interrupt the servicing of lower priority 
devices. 
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Figur* 4. Block XHagtam: 



Intamal II the CPU (in interrupt Mode 21 accepts an 

StructuT* interrupt, the interrupting device must provide 

(Continued) an 8'bit interrupt vector lor the CPU. This vec 
tor Icrms a pointer to a location in memory 
where the address o( the interrupt service 
routine-is 4<5cated. The 8- bit vector (rem the 
interrupting device lorms the least signilicant 
eight bits ol the indirect pointer while the 
I Register in the CPU provides the most signifi- 
cant eight bits ol the pointer. Each port (A and 
B) has an independent interrupt vector. The 
least significant bit ol the vector is automati- 
cally set to within the PIG because the 
pointer must point to two adjacent memory 
locations lor a complete 16- bit address. 

Unlike the other Z-80 peripherals, the PIG 
does not enable interrupts immediately alter 
programming), It waits until Ml goes^Low (e.g., 
during an opcode letch). This condition is 
unimportant in the Z-80 environment but might 
not be il anotlier type ol CPU is used. 
The PIG decodes the RETI (Return From 



Interrupt) instruction directly from the CPU 
data bus so that each PIG in the system knows 
at all times whether it is being serviced by the 
CPU interrupt service routine. No other com- 
munication with the CPU is required. 

CPU Bun I/O Logic. The CPU bus interlace 
logic interlaces the Z-80 PIG directly to the 
Z-80 CPU. so no external logic is necessary. 
For large systems, however, address decoders 
and/or bulfers may be necessary. 

Intamal Control Logic. This logic receives the 
control words for each port duMng program- 
ming and, in turn, controls the operating func- 
tions ol the Z-80 PIG. The control logic syn- 
chronizes the port operations, controls the port 
mode, port addressing, selects the read/write 
function, and issues appropriate commands to 
the ports and the interrupt logic. The Z-80 PIG 
does not receive a w rite input from t he CPU; 
instead, the RD, CE, C/D and IGRQ signals 
generate the write input internally. 
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Figur* S. Typical Port I/O Block Diagram 



Progretmmlng Mod* 0, L or 2. (Byte Input Output, or 

Bidirectional). Programming a port for Mode 
0, 1, or 2 requires two words per port. These 
words are: 

A Mod* Control Word. Selects the port operating mode 
(Figure 6). This word may be written «ny time. 

An Int*rrupt Victor. The Z-80 PIO is designed for use with 
the Z-80 CPU in interrupt Mode 2 (Figure 7). When inter- 
rupts are enabled, the PIO must provide an interrupt 
vector. 

Mod* 3- (Bit Input/Output). Programming a 
port for Mode 3 operation requires a control 
word, a vector (if interrupts are enabled), and 
three additional words, described as follows: 

I/O Rogistar Control. When Mode 3 is selected, the mode 
control word must be followed by another control word that 
sets the I/O control register, which in turn defines which 
port lines are inputs and which are outputs (Figure 8). 
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]|jit«TTupt Control Word. In Mode 3, handshake is not 
used. Interrupts are generated as a logic function of the 
input signal levels. The interrupt control word seta the 
logic conditions and the logic levels required for gener- 
ating an interrupt. Two logic conditions or functions are 
available: AND (if all input bits change to the active level, 
an interrupt is triggered), and OR (if any one of the input 
bits changes to the active level, an interrupt is triggered). 
Bit Dg sets the logic function, as shown in Figure 9. The 
active level of the input bits can be set either High or Low. 
The active level is controlled by Bit D5. 

Mask Control Word. This word sets the mask control 
register, allowing any unused bits to be masked off. If any 
bits ai-e to be masked, then D4 must be set. When D4 is set, 
the next word written to the port must be a mask control 
word (Figure 10). 

!iit«mipt Dlsabl«. There is one other control 
word which can be used to enable or disable a 
port interrupt. It can be used without changing 
the rest of the interrupt control word 
(Figure 11). 
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Figum R. Mod* Conlrol Word 



FisruT* 9. Interrupt Control Word 
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Pin A0-A7. Port A Bus (bidirectional, 3-state). 

Description. This 8-bit bus transfers data, status, or control 
information between Port A of the PIO and a 
peripheral device. Aq is the least significant 
bit of the Port A data bus. 
ARDY. Register A Ready (output, active 
High). The meaning of this signal depends on 
the mode of operation selected for Port A as 
follows: 

Output Mode. This signal goes active to indicate that the 
Port A output register has been loaded and the peripheral 
data bus is stable and ready for transfer to the peripheral 
device. 

Input Mode. This signal is active when the Port A input 
register is empty and ready to accept data from the 
peripheral device. 

Bidirectional Mode. This signal is active when data is 
available in the Port A output register for transfer to the 
peripheral device. In th is mod e, data is not placed on the 
Port A data bus, unless ASTB is active. 

Control Mode. This signal is disabled and forced to a Low 
state. 



ASTB. Port A Strobe Pulse From Peripheral 
Device (input, active Low). The meaning of 
this signal depends on the mode of operation 
selected for Port A as follows: 

Output Mode. The positive edge of this strobe is issued by 
the peripheral to acknowledge the receipt of data made 
available by the PIO. 

Input Mode. The strobe is issued by the peripheral to load 
data from the peripheral into the Port A input registeV. 
Data is loaded into the PIO when this signal is active. 

Bidirectional Mode. When this signal is active, data from 
the Port A output register is gated onto the Port A bidirec- 
tional data bus. The positive edge of the strobe acknowl- 
edges the receipt of the data. 

Control Mode. The strobe is inhibited internally. 

B0-B7. Port B Bus (bidirectional, 3-state). This 
8-bit bus transfers data, status, or control 
information between Port B and a peripheral 
device. The Port B data bus can supply 
1.5 mA at 1.5 V to drive Darlington transistors. 
Bq is the least significant bit of the bus. 

B/A. Port BOrA Select (input, High = B). 
This pin defines which port is accessed during 
a data transfer between the CPU and the PIO. 
A Low on this pin selects Port A; a High 
selects Port B. Often address bit Aq from the 
CPU is used for this selection function. 

BHDY. Register B Ready (output, active High). 
This signal is similar to ARDY, except that in 
the Port A bidirectional mode this signal is 
High when the Port A input register is empty 
and ready to accept data from the peripheral 
device. 



BSTB. Port B Strobe Pulse From Peripheral 
Device (i nput, a ctive Low). This signal is 
similar to ASTB, except that in the Port A 
bidirectional mode this sigiial strobes data 
from the peripheral device into the Port A 
input register. 



C/D. Co/i/roy Or Doto Se/ec/ (input. 
High = C). This pin defines the type of data 
transfer to be performed between the CPU and 
the PIO. A High on this pin during a CPU 
write to the PIO causes the Z-80 data bus to be 
interpreted as a command for the port selected 
by the BAS Select line. A Low on this pin 
means that the Z-80 data bus is being used to 
transfer data between the CPU and the PIO. 
Often address bit Aj from the CPU is used for 
this function. 

CE. Chip Enable (input, active Low). A Low 
on this pin enables the PIO to accept com- 
mand or data inputs from the CPU during a 
write cycle or to transmit data to the CPU dur- 
ing a read cycle. This signal is generally 
decoded from four I/O port numbers for Ports 
A and B, data, and control. 
CLK. System Clock (input). The Z-80 PIO uses 
the standard single-phase Z-80 system clock. 

D0-D7. Z-80 CPU Data Bus (bidirectional, 
3-state). This bus is used to transfer all data 
and commands between the Z-80 CPU and the 
Z-80 PIO. Do is the least significant bit. 

lEI. Interrupt Enable In (input, active High). 
This signal is used to form a priority- interrupt 
daisy chain when more than one interrupt- 
driven device is being used. A High level on 
this pin indicates that no other devices of 
higher priority are being serviced by a CPU 
interrupt service routine. 

lEO. Interrupt Enable Out (output, active 
High). The lEO signal is the other signal 
required to form a daisy chain priori^ scheme. 
It is High only if lEI is High and the CPU is 
not servicing an interrupt from this PIO. Thus 
this signal blocks lower priority devices from 
interrupting while a higher priority device is 
being serviced by its CPU interrupt service 
routine. 

INT. Interrupt Req uest (output, open drain, 
active Low). When INT is active the Z-80 PIO 
is requesting an interrupt from the Z-80 CPU. 

lORQ. Input/Outp ut Req uest (input from Z-80 
CPU, active Low). lORQ is used in conjunc- 
tion with B/A, C/D, CE, and RD to transfer 
commands and data between the Z-80 C PU and 
the Z-80 PIO. When CE, RD, and KffiO are 
active, the port addressed by B/A transfers 

data to the CP U (a rea d oper ation). Con- 

versely, when CE and lORQ are active but RD 
is not, the port addressed by B/5 is written 
into from the CPU with either data or control 
inform ation, as specified by C/D. Also, if 
lORQ and Ml are active simultaneously, the 
CPU is acknowledging an interrupt; the inter- 
rupting port automatically places its interrupt 
vector on the CPU data bus if it is the highest 
priority device requesting an interrupt. 



Pin Ml. Machine Cycle (input (rom CPU, active 

Description Low). This signal is used as a sync pulse to 
(Continued) control several internal PIO operations. When 
both the Ml and RD signals are active, the 
Z-80 CPU is fetching an instruction from 
memo ry. Conversely, when both Ml and 
lORQ are active, the CPU is acknowledging 
an interrupt. In addition, Ml has two other 
functions within the Z-80 PIO: it synchronizes 



the PIO interrupt logic; when Ml occurs 
without an active RD or lORQ signal, the PIO 
is reset. 

m. Read Cycle Status (input from Z-80 CPU, 
active Low). If RD is active, or an I/0_opera- 
tion is in progr ess, RD is used with B/A, C/D, 
CE, and lORQ to transfer data from the Z-80 
PIO to the Z-80 CPU. 



Timing The following timing diagrams show typical 

timing in a Z-80 CPU environment. For more 
precise specifications refer to the composite 
ac timing diagram. 

Writ* Cycl*. Figure 12 illustrates the 
timing for programming the Z-80 PIO 
or for writing data to one of its ports. No 
Wait states are allowed for writing to the 
PIO other than the automatically inserted 
TwA- The PIO does not receive a speci- 
fic write signal; It internally generates 
Its own from the lack of an active 
RD signal. 
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Hgan 12. Writ* C^l* Timing 



R*ad Cyd*. Figure 13 illustrates the timing 
for reading the data input from an external 
device to one of the Z-80 PIO ports. No Wait 
states are allowed for reading the PIO other 
than the automatically inserted T^A- 

Chttput Mod* (Mod* 0). An output cycle 
(Figure 14) is always started by the exec ution 
of an output instruction by the CPU. The WR* 
puke from the CPU latches the data from the 
CPU data bus into the selected port's output 
register. The WR* pulse sets the Ready flag 
after a Low-going edge of CLK, indicating 
data is available. Ready stays active until the 
positive edge of the , trobe line is received, 
Indicating that data was taken by the periph- 
eral. The pos itive edge ol the strobe pulse 
generates an INT If the interrupt enable flip- 
flop has been set arid if this device has the 
highest priority. 
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Timing Input Mod* (Mod* 1). When STROBE goes 

(Continued) Low, data is loaded into the selected port input 
register (Figure 15). The next rising edge of 
strobe activates INT, if Interrupt Enable is set 
and this is the highest-priority requesting 
device. The following falling edge of CLK 
resets Ready to an inactive state, indicating 



that the input register is full and cannot accept 
any more data until the CPU completes a read. 
When a read is complete, the positive edge of 
RD seta Ready at the next Low-going transition 
of CLK. At this time new data can be loaded 
into the PIO. 




*RD = HD • CE > C/D • lORQ 

Flgur* 15. Mod* 1 Input Timing 



Bidiroctional Moda (Mod* 2). This is a com- 
bination of Modes and 1 using all four hand- 
shake lines and the eight Port A I/O lines 
(Figure 16). Port B must be set to the bit mode 
and its inputs must be masked. The Port A 
handshake lines are used for output control 
and the Port B lines are used for input control. 



If interrupts occur. Port A's vector will be used 
during port output and Port B's will be used 
during port input. Dat a is al lowed out onto the 
Port A bus only when ASTB is Low. The rising 
edge of this strobe can be used to latch the 
data into the peripheral. 




■Vm = HD • CE • C/D • lOBQ 

Figur* IS. Mod* 2 Bldbactlonol Timing 
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Timing Bit Mod* (Mod* 3). The bit mode does not 

(Continued) utilize the handshake signals, and a normal 

port write or port read can be executed at any 
time. When writing, the data is latched into 
the output registers with the same timing as the 
output mode (Figure 17). 

When reading the PIO, the data returned to 
the CPU is composed of output register data 
from those port data lines assigned as outputs 
and input register data from those port data 



lines assigned as inputs. The input register 
contains data that was present immediately 
prior to the falling edge of RD. An interrupt is 
generated if interrupts from the port are 
enabled and the data on the port data lines 
satisfy the logical equation defined by the 8-blt 
mask and 2- bit mask control registers. How- 
ever, if Port A is programmed in bidirectional 
mode, Port B does not issue an interrupt in bit 
mode and must therefore be polled. 
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Imtenrnpt Acknowladg* Timing. During Ml 
time, peripheral controllers are inhibited from 
changing their interrupt enable status, permit- 
ting the Interrupt Enable signal to ripple 
through the daisy chain. The periphera l with 
lEI High and lEO Low during INTACK places 
a preprogrammed 8-bit interrupt vector on the 
data bus at this time (Figure 18). lEO is held 
Low until a Return From Interrupt (RETI) 
instruction is executed by the CPU while lEI is 
High. The 2-byte RETI instruction is decoded 
internally by the PIO for this purpose. 
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Figur* 18. Entomipt Acknowl*dg« Timing 



E*tum From Intomipt Cycle. If a Z-80 per- 
ipheral has no interrupt pending and is not 
under service, then its lEO = lEI. If it has an 
interrupt under service (i.e., it has already 
interrupted and received an interrupt acknowl- 
edge) then its lEO is always Low, inhibiting 
lower priority devices from interrupting. If it 
has an interrupt pending which has not yet 
been acknowledged, lEO is Low unless an 
"ED" is decoded as the first byte of a 2-byte 
opcode (Figure 19). In this case, lEO goes 
High until the next opcode byte is decoded, 
whereupon it goes Low again. If the second 
byte of the opcode was a "4D," then the 
opcode was an RETI instruction. 

After an "ED" opcode is decoded, only the 
peripheral device which has interrupted and is 
currently under service has its lEI High and its 



lEO Low. This device is the highest-priority 
device in the daisy chain that has received an 
interrupt acknowledge. All other peripherals 
have IE! = lEO. If the next opcode byte 
decoded is "4D," this peripheral device resets 
its "interrupt under service" condition. 

T, Tj T, T* 7, Tj T, T;, T, 

- jiJijijnjnxiJ~LrLrL 

J — \ / 




/ \ r 



-CE> 



<Ey 



Flgur* 19^ R«tu]rtt From Inlanrupit 



2006-0329, 0330, 0331 



AC 

Charac- 
teristics 




MumlMr STnbol 


jP(U4XUMt#r 


Mia Mas 

(M) (m) 


MIti Mas 

(M) (M) 


Kin Max 

(») (m) 




1 


TcC 


Clock Cycle Time 


400 


HI 


250 


(1) 


165 


[11 




2 


TwCh 


Clock Width (High) 


170 


2000 


105 


2000 


65 


2000 




3 


TwCl 


Clock Width (Low) 


170 


2000 


105 


2000 


65 


2000 




4 


TIC 


Clock Fall Time 




30 




30 




20 




5 — 


-TrC 


- Clock Rise Time 
















6 


TsCS(RI) 


CE, B/A, C/D to Id, 
lORQ 1 Sehap Time 


50 




50 




50 




16) 


7 


Th 


Any Hold Times for Specified 
Setup Time 




















8 


TsRI(C) 


Id, lORQ to Clock 1 Setup 
Time 


115 




115 




70 






9 — 


- TdRI(DO) 
















(21 


10 


TdRI(DOa) 


RD, lORQ t to Data Out Float 
Delay 




160 




110 




70 




11 


TaDI(C) 


Data In to Clock t Setup Time 


50 




50 




40 




CL = 50 pF 


12 


TdlCKDOI) 


lORQ I to Data Out Delay 
(INTACK Cycle) 

- Ml I to Clock t Setup Time 


340 
-210- 




160 




120 




(3) 


13 — 


-TsMl(Cr) 














14 


TsMKCO 


Ml t to Clock I Setup Time 
(Ml Cycle) 

















[81 


15 


TdMl(IEO) 
TsIEI(IO) 
-TdlEI(IEOf)— 


Ml i to lEO I Delay (Interrupt 
Immediately Preceding Ml 1) 


140 


300 


140 


190 


100 


100 


(5,7) 


16 


lEI to lORQ 1 Setup Time 
(INTACK Cycle) 

- lEI 1 to lEO J Delay- ■ 


[71 


17 














PI 

CL = 50 pF 


18 


TdlEI(IEOr) 


lEI t to lEO I Delay (after ED 
Decode) 




210 




160 




160 


15) 


19 

20- 


ToIO(C) 
-TdC(RDYr)— 


lORQ t to Clock 1 Setup Time 
(To Activate READY on Next 
Clock Cycle) 

- Clock 1 to READY t Delay 


220 
-200- 




200 
-190- 




170 
-170- 












CL = 50 pF 


21 


TdC(RDYf) 


Clock t to READY t Delay 


150 




140 




120 




(51 


22 


TwSTB 


STROBE Pulse Width 


ISO 




150 




120 




£4) 


23 


TsSTB(C) 


STROBE 1 to Clock i Setup 
Time (To Activate READY on 
Next Clock Cycle) 


220 




220 




150 




(5) 


24- 


-TdlO(PD) 

TsPD(STB) 


- lORQ 1 to PORT DATA Stable - 
Delay (Mode 0) 
















260 


200 


230 


180 


190 


160 


(5) 


25 


PORT DATA to STROBE t 
Setup Time (Mode 1) 




26 


TdSTB(PD) 


STR06E I to PORT DATA 
Stable (Mode 2) 




230 




210 




180 


(5) 


27 - 


-TdSTB(PDr)- 


-STrOBE t to PORT DATA Float 
Delay (Mode 2) 


















200 




180 




160 


CL = 50 pF 


28 


TdPD(INT) 


PORT DATA Match to INT 1 
Delay (Mode 3) 




540 




490 




430 




29 


TdSTB(INT) 


'5TBOBE t to INT J Delay 




490 




440 




350 





NOTES: 
ID TcC = TwCh + TwCl + TrC + TfC. 
(21 IncreoBe TdRI(DO) by 10 ns for each 50 pF increase in load 

up to 200 pF max. 
(31 Increase TdlO(DOI) by 10 na (or each 50 pF, increose in 

loading up to 200 pF max. 
[4] For Mode 2: TwSTB > TsPp(STB). 
[51 Increase these values by 2 ns for each 10 pF increase in 

loading up to 100 pF max. 



|6) TflCS(RI) may be reduced. However, the time subtracted 

from TsCSCRI) will be added to TdRI(DO). 
(71 2.5 TcC > (N-2)TdIEI(IEOf) -.- TdMl(IEO) + TalEldO) 

+ TTL Bulfer Delay, ii any. 
181 HI must be active for a minimum of two clock cycles to 

reset the PIO. 
(9) Z80B PIO numbers are preliminary and subject to change. 



Absolute Voltages on all inputs and outputs 

Maximum with respect to GND -0.3 V to +7.0 V 

Ratings Operating Ambient 

Temperature As Specified in 

Ordering Information 

Storage Temperature -65°C to +150°C 



Test 
Conditions 



Stresses greater than those listed under Absolute Maxi- 
mum Ratings may cause permanent damage to the device. 
This is a stress rating only: operation of the device at any 
condition above those indicated in the operational sections 
oi these specifications is not implied. Exposure to absolute 
maximum rating conditions for extended periods may affect 
device reliability. 



The characteristics below apply for the 
following standard test conditions, unless 
otherwise noted. All voltages are referenced to 
GND (0 V). Positive current flows into the 
refefericed pin. Available operating 
temperature ranges are: 

■ 0°to +70°C, 

+ 4.75 V <. Vcc ^ +5.25 V 

■ -40°C to +85°C, 

+ 4.75 V £ Vcc s +5.25 V 

■ -55° to + 125°C, 

+ 4.75 V < Vcc s +5.5 V 
The product number for each operating 
temperature range may be found in the 



Ordering Information section. 

All ac parameters assume a load capacitance 
of 100 pF max. Timing references between two 
output signals assume a load difference of 
50 pF max. 



DC 


Symbol 


Parameter 


Min 


Max 


Unit 


Test Condition 


Charac- 
teristics 


ViLC 


Clock Input Low Voltage 


-0.3 


+ 0.45 


V 






V,HC 


Clock Input High Voltage 


Vcc-0.6 


+ 5.5 


V 






V,L 


Input Low Voltage 


-0.3 


+ 0.8 


V 






V,H 


Input High Voltage 


+ 2.0 


+ 5.5 


V 






Vol 


Output Low Voltage 




+ 0.4 


V 


Iql = 2.0 mA 




VOH 


Output High Voltage 


+ 2.4 




V 


loH = -250 ;uA 




Ili 


Input Leakage Current 


-10.0 


+ 10.0 


M 


0<VlN<VcC 




h 


3-State Output/Data Bus Input Leakage Current 


-10.0 


+ 10.0 


M 


0<VlN<VcC 




tc 


Power Supply Current 




100.0 


mA 


VoH = l-5V 




loHD 


Darlington Drive Current 


-1.5 


3.8 


mA 


Rext = 390 a 




Over specified temperature and voltage range. 










Capacitance 


SymlMl 


Parameter 


Min 


Max 


Unit 


Test Condition 




C 

"-•GUT 


Clock Capacitance 
Input Capacitance 
Output Capacitance 




10 
5 
10 


pF 
pF 
pF 


Unmeasured 
pins returned 
to ground 



Over specitied temperature range; f = IMHj, 



APPENDIX C 
Z80A/Z80B COUNTER/TIMER CIRCUIT (CTC) 



Z8430 

280* CTC Counter/ 

Timer Circnlt 



Zilog 



Product 
Specification 



March 1981 



Fmcttaxm* ■ Four independently programmable 

counter/timer channels, each with a 
readable downcounter and a selectable 
16 or 256 prescaler. Downcounters are 
reloaded automatically at zero count. 

■ Three channels have Zero Count/Timeout 
outputs capable of driving Darlington 
transistors. 



Selectable positive or negative trigger 
initiates timer operation. 

Standard Z-80 Family daisy-chain interrupt 
structure provides fully vectored, prioritized 
interrupts without external logic. The CTC 
may also be used as an interrupt controller. 

Interfaces directly to the Z-80 CPU or — for 
baud rate generation — to the Z-80 SIC 



G«n«ral The Z-80 CTC four-channel counter/timer 

D*acrlptlon can be programmed by system software for a 
broad range of counting and timing applica- 
tions. The four independently programmable 
channels of the Z-80 CTC satisfy common 
microcomputer system requirements for event 
counting, Interrupt and interval timing, and 
general clock rate generation. 

System design is simplified because the CTC 
connects directly to both the Z-80 CPU and the 
Z-80 SIO with no additional logic. In larger 
systems, address decoders and buffers may be 
required. 

Programming the CTC is straightforward: 



each channel is programmed with two bytes; a 
third is necessary when interrupts are enabled. 
Once started, the CTC counts down, reloads 
its time constant automatically, and resumes 
counting. Software timing loops are completely 
eliminated. Interrupt processing is simplified 
because only one vector need be specified; the 
CTC internally generates a unique vector for 
each channel. 

The Z-80 CTC requires a single +5 Y power 
supply and the standard Z-80 single-phase 
system clock. It is fabricated with n-channel 
silicon-gate depletion- load technology, and 
packaged in a 28-pin plastic or ceramic DIP. 
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Functional The Z-80 CTC has four independent counter/ 

Description timer channels. Each channel is indivia-jally 
programmed with two words: a control word 
and a time-constant word. The control wora 
selects the operating mode (counter or timer), 
enables or disables the channel interrupt, and 
selects certain other operating parameters. If 
the timing mode is selected, the control word 
also sets a prescaler, which divides the system 
clock by either 16 or 256. The time-constant 
word is a value from 1 to 256. 

During operation, the individual counter 
channel counts down from the preset time con- 
stant value. In counter mode operation the 
counter decrements on each of the CLK/TRG 
input pulses until zero count is reached. Each 
decrement is synchronized by the system 
clock. For counts greater than 256, more than 
one counter can be cascaded. At zero count, 
the down-counter is automatically reset with 
the time constant value. 

The timer mode determines time intervals as 
small as 4 fss (Z-80A) or 6.4 jts (Z-80) without 
additional logic or software timing loops. Time 
intervals are generated by dividing the system 
clock with a prescaler that decrements 



ArcWtecture The CTC has four major elements, as shown 
in Figure 3. 

B CPU bus I/O 

■ Channel control logic 

■ Interrupt logic 

B Clounter/timer circuits 

CPU Bus I/O. The CPU bus I/O circuit 
decodes the address inputs, and interfaces the 
CPU data and control signals to the CTC for 
distribution on the internal bus. 



a preset down-counter. 

Thus, the time interval is an integral mul- 
tiple of the clock period, the prescaler value 
(16 or 256) and the time constant that is preset 
in the down-counter. A timer is triggered auto- 
matically when its time constant value is pro- 
grammed, or by an external CLK/TRG input. 

Three channels have two outputs that occur 
at zero count. The first output is a zero- 
count/timeout pulse at the ZC/TO output. The 
fourth channel (Channel 3) does not have a 
ZC/TO output; interrupt request is the only 
output available from Channel 3. 

Th e second output is Interrupt Request 
(INT), which occurs if the channel has its 
interrupt enabled during programming. When 
the Z-80 CPU acknowledges Interrupt Request, 
the Z-80 CTC places an interrupt vector on the 
data bus. 

The four channels of the Z-80 CTC are fully 
prioritized and fit into four contiguous slots in 
a standard Z-80 daisy-chain int'^rnipt stmr- 
ture. Channel is the highest priority and 
Channel 3 the lowest. Interrupts can be 
individually enabled (or disabled) for each of 
the four channels. 



Internal Control Logic. The CTC internal 
control logic controls overall chip operating 
functions such as the chip enaDie, reset, and 
read/write logic. 

Interrupt Logic. The interrupt control logic 
ensures that the CTC inte-rupts interface prop- 
erly with the Z-80 CPU interrupt system. The 
logic controls the interrupt priority of the CTC 
as a function of the lEI signal. If lEI is High, 
the CTC has priority. During ;;,;>,. ,-upt 
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Flgun 3. Functional Block Diagram 



Archlt*ctiur« processing, the interrupt logic hdck lEO Low, 
(Continued) which inhibits the interrupt operation on lower 
priority devices. If the lEI input goes Low, 
priority is relinquished and the interrupt logic 
drives lEO Low. 

If a channel is programmed to request an 
interrupt, the interrupt logic driv es lE O Low at 
the zero count, and generates an INT signal to 
the Z-80 CPU. When the Z-80CPU r espon ds 
with interrupt acknowledge (Ml and lORQ), 
then the interrupt logic arbitrates the CTC 
internal priorities, and the interrupt control 
logic places a unique interrupt vector on the 
data bus. 

If an interrupt is pending, the interrupt logic 
holds lEO Low. When the Z-80 CPU issues a 
Return From Interrupt (RETI) instruction, each 
peripheral device decodes the first byte 
(ED)6). If the device has a pending interrupt, 
it raises lEO (High) for one Ml cycle. This 
ensures that all lower priority devices can 
decode the entire RETI instruction and reset 
properly. 
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FIgtu* 4. Caunlar/Tlmar Block Diagram 

Countm/Tlmer Circuits. The CTC has four 
independent counter/timer circuits, each con- 
taining the logic shown in Figure 4. 

Channol Control Logic. The channel control 
logic receives the 8-bit channel control word 
when the counter/timer channel is pro- 
grammed. The channel control logic decodes 



the control woord and sets the idkwing 
operating oooditims: 

■ Interrupt enable (or disable) 

■ Operating mode (tinier or counter) 

■ Timer mode prescaler factor (16 en- ^6) 

■ Active sbpe for CLK/THG input 

■ Timer mode trigger (automatic or CLK/THG 
input) 

■ Time constant data word to follow 

■ Software reset 

Tlm« Conatont Register. When the counter/ 

timer channel is programmed, the time con- 
stant register receives and stores an 8-bit time 
constant value, which can be anywhere from 1 
to 256 (0 = 256). This constant is automatic- 
ally loaded into the down-oounter when the 
counter/timer channel is initialized, and subse- 
quently after each zero count. 

Pretcalar. The prescaler, which is used only 
in timer mode, divides the system clock fre- 
quency by a factor of either 16 or 256. The 
prescaler output clocks the down-counter dur- 
ing timer operation. The effect of the prescaler 
on the down-counter is a multiplication oJ the 
system clock period by 16 or 2S6. The pre- 
scaler factor is programmed by bit 5 erf the 
channel control word. 

Down-Counter. Prior to each count cycle, the 
down- counter is loaded with the time constant 
register contents. The counter is then 
decremented one of two ways, depending on 
operating mode: 

■ By the prescaler output (timer mode) 

■ By the trigger pulses into the CLK/TRG 
input (counter mode) 

Without disturbing the down-count, the Z-80 
CPU can read the count remaining Sit any time 
by performing an I/O read operation at the 
port address assigned to the CTC channel. 
When the down-counter reaches the zero 
count, the ZC/TO outpu: generates a positive- 
going pulse. When the i .arrupt is enabled, 
zero co unt also triggers ^.,i interrupt request 
signal (INT) from the inii. rupt logic. 
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Progiamming Eadht Z-80 CTC channel must be pro- 
grammed prior to operation. Programming 
consists of writing two words to the I/O port 
that corresponds to the desired channel. The 
lirst word is a control word that selects the 
operating mode and other parameters; the 
second word is a time constant, which is a 
binary data word with a value from 1 to 256. A 
time constant word must be preceded by a 
channel control word. 

After initialization, channels may be 
reprogrammed at any time. If updated control 
and time constant words are written to a chan- 
nel during the count operation, the count con- 
tinues to zero before the new time constant is 
loaded into the counter. 

If the interrupt on any Z-80 CTC channel is 
enabled, the programming procedure should 
also include an interrupt vector. Only one vec- 
tor is required for all four channels, because 
the interrupt logic automatically modifies the 
vector for the channel requesting service. 

A control word is identified by a 1 in bit 0. 
A in bit 2 indicates a time constant word is to 
fdSom. Interrupt vectors are always addressed 
to Channel 0, and identified by a in bit 0. 

Addressing. During programming, channels 
are addrawed with the channel select pins CSj 
and CSa- A 2-bit binary code selects the 
appsoprtate channel as shown in the following 
table. 

Qunmsl CSi CSq 
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HM«f. The CTC has both hardware and soft- 
ware resets. The hardware reset terminates all 
down-ODunte and disables all CTC interrupts 
by ret^fting the interrupt bits in the control 
registers. In addition, the ZC/TO and Interrupt 
outputs go inactive, lEO reflects lEI, and 



D0-D7 go to the high- impedance state. All 
channels must be completely reprogramjned 
after a hardware reset. 

The software reset is controlled by bit 1 in 
the channel control word. When a channel 
receives a software reset, it stops counting. 
When a software reset is used, the other bits in 
the control word also change the contents of 
the channel control register. After a software 
reset a new time constant word must be written 
to the same channel. 

If the channel control word has both bits Dj 
and D2 set to 1, the addressed channel stops 
operating, pending a new time constant word. 
The channel is ready to resume after the new 
constant is programmed. In timer mode, if 
D3 = 0, operation is triggered automatically 
when the time constant word is loaded. 

Channel Control Word Programming. The 

channel control word is shown in Figure 5. It 
sets the modes and parameters described 
below. 

Interrupt Enable. D7 en ables the interrupt, so 
that an interrupt output (INT) is generated at - 
zero count. Interrupts may be programmed in 
either mode and may be enabled or disabled 
at any time. 

Operating Mode. Dg selects either timer or 
counter mode. 

Prescaler Factor. (Timer Mode Only). D5 

selects factor — either 16 or 256. 

Trigger Slope. D4 selects the active edge or 
slope of the CLK/TRG input pulses. Note that 
reprogramming the CLK/TRG slope during 
operation is equivalent to issuing an active 
edge. If the trigger slope is changed by a con- 
trol word update while a channel is pending 
operation in timer mode, the result is the same 
as a CLK/TRG pulse and the timer starts. 
Similarly, if the channel is in counter mode, 
the counter decrements. 
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Programming Trigger Mode (Timer Mode Only). D3 selects 
(Continued) the trigger mode for timer operation. When D3 
is reset to 0, the timer is triggered automatic- 
ally. The time constant word is programmed 
during an I/O write operation, which takes one 
machine cycle. At the end of the write opera- 
tion there is a setup delay of one clock period. 
The timer starts automatically (decrements) on 
the rising edge of the second clock pulse (T2) 
of the machine cycle following the write opera- 
tion. Once started, the timer runs contin- 
uously. At zero count the timer reloads 
automatically and continues counting without 
interruption or delay, until stopped by a reset. 

When D3 is set to 1 , the timer is triggered 
externally through the CLK/TRG input. The 
time constant word is programmed during an 
I/O write operation, which takes one machine 
cycle. The timer is ready for operation on the 
rising edge of the second clock pulse (T2) of 
the following machine cycle. Note that the first 
timer decrement follows the active edge of the 
CLK/TRG pulse by a delay time of one clock 
cycle if a minimum setup time to the rising 
edge of clock is met. If this minimum is not 
met, the delay is extended by another clock 
period. Consequently, for immediate trigger- 
ing, the CLK/TRG input must precede Tj by 
one clock cycle plus its minimum setup time. If 
the minimum time is not met, the timer will 
start on the third clock cycle (T3). 

Once started the timer operates contin- 
uously, without interruption or delay, until 
stopped by a reset. 

Time Constant to Follow. A 1 in Dj indicates 
that the next word addressed to the selected 
channel is a time constant data word for the 
time constant register. The time constant word 
may be written at any time. 

A in D2 indicates no tinr.e constant word is 
to follow. This is ordinarily used when the 
channel is already in operation and the new 
channel control word is an update. A channel 
will not operate without a time constant value. 
The only way to write a time constant value is 
to write a control word with D2 set. 



Software Reset. Setting D| to 1 causes a soft- 
ware reset, which is described in the Reset 
section. 

Control Word. Setting Do to 1 identifies the 
word as a control word. 

Tims Constant Programming. Before a chan- 
nel can start counting it must receive a time 
constant word from the CPU. During program- 
ming or reprogramming, a channel control 
word in which bit 2 is set must precede the 
time constant word to indicate that the next 
word is a time constant. The time constant 
word can be any value from 1 to 256 (Figure 
6). Note that 00 le is interpreted as 256. 

In timer mode, the time interval is controlled 
by three factors: 

■ The system clock period (<^) 

■ The prescaler factor (P), which multiplies 
the interval by either 16 or 256 

■ The time constant (T), which is programmed 
into the time constant register 

Consequently, the time interval is the pro- 
duct of <^xPxT. The minimum timer resolu- 
tion is \6x4> (4 us with a 4 MHz clock). The 
maximum timer interval is 256x<^x256 (16.4 ms 
with a 4 MHz clock). For longer intervals 
timers may be cascaded. 

Interrupt Vector Programming. If the Z-80 
CTC has one or more interrupts enabled, it 
can supply interrupt vectors to the Z-80 CPU. 
To do so, the Z-80 CTC must be pre-pro- 
grammed with the most- significant five bits of 
the interrupt vector. Programming consists of 
writing a vector word to the I/O port cor- 
responding to the Z-80 CTC Channel 0. Note 
that Do of the vector word is always zero, to 
distinguish the vector from a channel control 
word. Di and D2 are not used in programming 
the vector word. These bits are supplied by 
the interrupt logic to identify the channel 
requesting interrupt service with a unique 
interrupt vector (Figure 7). Channel has the 
highest priority. 
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PiB CE. Chip Enable (input, active Low). When 

DMcrlptton enabled the CTC accepts control words, inter- 
rupt vectors, or time constant data words from 
the data bus during an I/O write cycle; or 
transmits the contents of the down-counter to 
the CPU during an I/O read cycle. In most 
applications this signal is decoded from the 
eight least significant bits of the address bus 
lor any of the four I/O port addresses that are 
mapped to the four counter-timer channels. 

CLK. System Clock (input). Standard single- 
phase Z-80 system clock. 

CLK/THG0-CLK/TRG3. External Clock/Timer 
Trigger (input, user-selectable active High or 
. Low). Four pins corresponding to the tour Z-80 
CTC channels. In counter mode, every active 
edge on this pin decrements the down-counter. 
In timer mode, an active edge starts the timer. 

CSfl-CSi. Channel Select (inputs active High). 
Two-bit binary address code selects one of the 
four CTC channels for an I/O write or read 
(usually connected to Aq and A\). 

D0-D7. System Doto Bus (bidirectional, 
3-state). Transfers all data and commands 
between the Z-80 CPU and the Z-80 CTC. 




in. Interrupt Enable In 'input, active High). 
A High indicates tnat no other interrupting 
devices of higher priority in the daisy chain 
are being serviced by the Z-80 CPU. 

lEO. Interrupt Enable Out (output, active 
High). High only if lEI is High and the Z ':.0 
CPU is not servicing an interrupt from an . 
Z-80 CTC channel. lEO blocks lower priority 
devices from interrupting while a higher 
priority interrupting device is being serviced. 

INT. Interrupt Request (output, open drain, 
active Low). Low when any Z-80 CTC channel 
that has been programmed to enable interrupts 
has a zero-count condition in its down-counter. 



lORQ. Input/Output Request (input from CPU, 
active Low). Used with CE and RD to transfer 
data and channel control words between the 
Z-80 C PU an d the Z-80 CTC. During_a_ write 
cycle, lORQ and CE are active and RD 
inactive. The Z-80 CTC does not receive a 
specific write signal; rather, it internally 
gen erates its own from the i nverse oi an active 
RD signal. In a read cycle, lORQ, CE and RD 
are active; the contents of the down -counter 
are read by the Z-80 CPU. If lORQ and Ml are 
both true, the CPU is acknowledging an inter- 
rupt request, and the highest priority inter- 
rupting channel places its interrupt vector on 
the Z-80 data bus. 

Ml. Machine Cycle One (i nput fr om CPU, 
active Low). When Ml and lORQ are active, 
the Z-80 CPU is acknowledging an interrupt. 
The Z-80 CTC then places an interrupt vector 
on the data bus if it has highest priorit y, a nd if 
a channel has reguested an interrupt (INT). 

RD. Read Cycle Status (i nput, a ctive Low). 
Used in conjunction with lORQ and CE to 
transfer data ant! channel control words 
between the Z-80 CPU and the Z-80 CTC. 



RESET. Reset (input active Low). Terminates 
all down-counts and disables all interrupts by 
resetting the interrupt bits in all control 
registers; the ZC/TO and the Interrupt outputs 
go inactive; lEO reflects lEI; D0-D7 go to the 
high- impedance state. 

ZC/TOo-ZC/TOj. Zero Count/Timeout (output, 
active High). Three ZC/TO pins corresponding 
to Z-80 CTC channels 2 through (Channel 3 
has no ZC/TO pin). In both counter and timer 
modes the output is an active High pulse when 
the down-counter decrements to zero. 
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Interrupt The 2-80 CTC follows the Z-80 system inter- 

Op«rotioii rupt protocol for nested priority interrupts and 

return from interrupt, wherein the interrupt 
priority of a peripheral is determined by its 
location in a daisy chain. Two lines — lEI and 
lEO— in the CTC connect it to the system daisy 
chain. The device closest to the + 5 V supply 
has the highest priority (Figure 13). For addi- 
tional information on the Z-80 interrupt struc- 
ture, refer to the Z-8Q CPU Product SpeciUca- 
tion and the Z-80 CPU Technical Manual. 



HIOHMT mioiuTr 
mvicii 



LOWnT PRIOWTV 

OKWICR 



tSV 


DEVICE 


HI 


DEVICE 1 


HI 


DEVICE 3 


HI 


DEVICE 3 


Th, 


lEI rEO 


lei leo 


lEI lEO 


lEI lEO 









FlguT* IS. Daiitr-Chaln Inlnrnpt MoclIlM 

Within the Z-80 CTC, interrupt priority is 
predetermined by channel number: Channel 
has the highest priority, and Channel 3 the 
lowest. If a device or channel is being serviced 
with an interrupt routine, it cannot be inter- 
rupted by a device or channel with lower 
priority until service is complete. Higher 
priority devices or channels may interrupt the 
servicing of lower priority devices or channels. 

A Z-80 CTC channel may be programmed to 
request an interrupt every time its down- 
counter reaches zero. Note that the CPU must 
be programmed for interrupt mode 2. Some 
time after the interrupt request, the CPU sends 
an interrupt acknowledge. The CTC interrupt 
control logic determines the highest priority 
channel that is requestinq an interrupt. Then, 
if the CTC lEI input is High (indicating that it 
has priority within the system daisy chain) it 
places an 8-bit interrupt vector on the system 
data bus. The high-order five bits of this vector 



were written to the CTC during the program- 
ming process; the next two bits are provided 
by the CTC interrupt control logic as a binary 
code that identifies the highest priority chan- 
nel requesting an interrupt; the low-order bit 
is always zero. 

Interrupt Acknowladg* Timing. Figure 14 
shows interrupt acknowledge timing. After an 
interrupt request, the_Z-80 CPU s ends an inter- 
rupt acknowledge (Ml and lORQ). All chan- 
nels are inhibited from changing their inter- 
rupt request status when Ml i s activ e — about 
two clock cycles earlier than lORQ. RD is 
High to distinguish this cycle from an instruc- 
tion fetch. 

The CTC interrupt logic determines the 
highest priority channel requesting an inter- 
rupt. If the CTC interrupt jsnable input (lEI) is 
High, the highest priority interrupting channel 
within the CTC pla ces its interrupt vector on 
the data bus when lORQ goes Low. Two wait 
states (Twa) are automatically inserted at this 
time to allow the daisy chain to stabilize. Addi- 
tional wait states may be added. 

Return from Interrupt Timing. At the end of 

an interrupt service routine the RETI (Return 
From Interrupt) instruction initializes the daisy 
chain enable lines for proper control of nested 
priority interrupt handling. The CTC decodes 
the 2-byte RETI code internally and determines 
whether it is intended for a channel being ser- 
viced. Figure 15 shows RETI timing. 

If several Z-80 peripherals are in the daisy 
chain, lEI settles active (High) on the chip 
currently being serviced when the opcode 
EDi6 is decoded. If the following opcode is 
4Di6, the peripheral being serviced is released 
and its lEO becomes active. Additional wait 
states are allowed. 
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Timing Read Cycls Timing. Figure 9 shows read 

cycle timing. This cycle reads the contents of a 
down-counter without disturbing the count. 
During clock cycle Tj, the Z-80 CPU initiates a 
read cycle by dr iving the following inputs 
Low: RD, lORQ, and CE. A 2-bit binary code 
at inputs CSi and CSq selects the channel to 
be read. Ml must be High to distinguish this 
cycle from an interrupt acknowledge. No addi- 
tional wait states are allowed. 



latched into the appropriate register with the 
rising edge of clock cycle TwA- f^° edditional 
wait states are allowed. 
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Figur* 11. Tlmm Mod* Timing 
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Flgur* 9. Read CyclA Tlmlms^ 

Writ© Cycle Timing. Figure 10 shows write 
cycle liming for loading control, time constant 
or vector words. 

The CTC does not have a write signal input, 
so it generates one internally when the read 
(RD) i nput is H igh during Ti. During li 
lORQ and CE inputs are Low. Ml must be 
High to distinguish a write cycle from an inter- 
rupt acknowledge. A 2-bit binary code at 
inputs CS) and CSq selects the channel to be 
addressed, and the word being written is 
placed on the Z-80 data bus. The data word is 



Timer Operation. In the timer mode, a 
CLK/TRG pulse input starts the timer (Figure 
11) on t^e second 5ucceeding rising edge of 
CLK. The trigger puise is asynchronous, and it 
must have a minimum width. A minimum lead 
time (210 ns) is required between the active 
edge of the CLK/TRG and the next rising edge 
of CLK to enable the prescaler on the follow- 
ing clock edge. If the CLK/TRG edge occurs 
closer than this, the initiation of the timer 
function is delayed one clock cycle. This cor- 
responds to the startup timing discussed in the 
programming section. The timer can also be 
started automatically if so programmed by the 
channel control word. 




Flgura 12. Counter Mod* Timing 
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Flgiw* 10. Writ* Cyd* Timing 



Counter Operotion. In the counter mode, the 
CLK/TRG pulse input decrements the down- 
counter. The trigger is asynchronous, but the 
count is synchronized with CLK. For the 
decrement to occur on the next rising edge of 
CLK, the trigger edge must precede CLK by a 
minimum lead time as shown in Figure 12. If 
the lead time is less than specified, the count 
is delayed by one clock cycle. The trigger 
pulse must have a minimum width, and the 
trigger period must be at least twice the clock 
period. 

The ZC/TO output occurs immediately after 
zero count, and follows the rising CLK edge. 
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APPENDIX D 
Z80A/Z80B CENTRAL PROCESSING UNIT (CPU) 



Zilog 



Z8400 

ZSO'^CPU Central 
Processing Unit 



Product 
Specification 



March 1981 



FiKituurMi ■ The instruction set contains 158 instructions. 

The 78 instructions of the 8080A are 
included as a subset; 8080A software com- 
patibility is maintained. 

■ Six MHz, 4 MHz and 2.5 MHz cl cks for the 
Z80B, Z80A, and 280 CPU result in rapid 
instruction execution with consequent high 
data throughput. 

■ The extensive instruction set includes striiig, 
bit, byte, and word operations. Block 
searches and block transfers together with 
indexed and relative addressing result in 
the most powerful data handling capabilities 

' in the microcomputer industry. 

■ The Z80 microprocessors and associated 
family of peripheral controllers are linked 
by a vectored interrupt system. This system 



may be daisy-chained to allow implemen- 
tation of a priority interrupt scheme. Little, 
if any, additional logic is required for 
daisy-chaining. 

Duplicate sets of both general-purpose 
and flag registers are provided, easing 
the design and operation of system soft- 
ware through single-context switching, 
background-foreground programming, and 
single-level interrupt processing. In addi- 
tion, two 16-bit index registers facilitate 
program processing of tables and arrays. 

There are three modes of high speed inter- 
rupt processing: 8080 compatible, non-Z80 
peripheral device, and Z80 Family 
peripheral with or without daisy chain. 

On-chip dynamic memory refresh counter. 
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Figure 1. Pin Functions 



Figure 2. Pin Auignmants 
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G«n«ral The Z80, Z80A, and Z80B CPUs are third- 

D«HK3rlpUon generation single-chip microprocessors with 
exceptional computational power. They offer 
higher system throughput and more efficient 
memory utilization than comparable second- 
and third-generation microprocessors. The 
internal registers contain 208 bits of read/write 
memory that are accessible to the programmer. 
These registers include two sets of six general- 
purpose registers which may be used 
individually as either 8-bit registers or as 
16-bit register pairs. In addition, there are two 
sets of accumulator and flag registers. A group 
of "Exchange" instructions makes either set of 
main or alternate registers accessible to the 
programmer. The alternate set allows operation 
in foreground-background mode or it may 



be reserved for very fast interrupt resp>onse. 
The 280 also contains a Stack Pointer, Pro- 
gram Counter, two index registers, a Refresh 
register (counter), and an Interrupt register. 
The CPU is easy to incorporate iinto a system 
since it requires only a single + 5 V power 
source, all output signals are fully decoded 
and timed to cpntrol standard memory or 
peripheral circuits, and is supported by an 
extensive family of peripheral controllers. The 
internal block diagram (Figure 3) shows the 
primary functions of the Z80 processors. 
Subsequent text provides more detail on the 
Z80 I/O controller family, registers, instruction 
set, interrupts and daisy chaining, and CPU 
timing. 
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Z80 Micro- The Zilog Z80 microprocessor is the central 

processor element of a comprehensive microprocessor 

Fomily product family. This family works together in 

most applications with minimum requirements 
for additional logic, facilitating the design of 
efficient and cost-effective microcomputer- 
based systems. 

Zilog has designed five components to pro- 
vide extensive support for the Z80 micro- 
processor. These are: 

■ The PIO (Parallel Input/Output) operates in 
both data-byte I/O transfer mode (with 
handshaking) and in bit mode (without 
handshaking). The PIO may be config- 
ured to interface with standard parallel 
peripheral devices such as printers, 

tape punches, and keyboards. 

■ The CTC (Counter/Timer Circuit) features 
four programmable 8-bit counter/timers. 



each of which has an 8 bit prescaler. Each 
of the four channels may be configured to 
operate in either counter or timer mode. 

The DMA (Direct Memory Access) con- 
troller provides dual port data transfer 
operations and the ability to terminate data 
transfer as a result of a pattern match. 

The SIO (Serial Input/Output) controller 
offers two channels. It is capable of 
operating in a variety of programmable 
modes for both synchronous and asyn- 
chronous communication, including 
Bi-Synch and SDLC. 

The DART (Dual Asynchronous Receiver/ 
Transmitter) device provides low cost 
asynchronous serial communication. It has 
two channels and a full modem control 
interface. 



Z80 CPU Figure 4 shows three groups of registers 

Registers within the Z80 CPU. The first group consists of 

duplicate sets of 8-bit registers; a principal set 
and an alternate set (designated by ' [prime], 
e.g., A'). Both sets consist of the Accumula- 
tor Register, the Flag Register, and six 
general-purpose registers. Transfer of data 
between these duplicate sets of registers is 
accomplished by use of "Exchange" instruc- 
tions. The result is faster response to interrupts 
and easy, efficient implementation of such ver- 
satile programming techniques as background- 



foreground data processing. The second set of 
registers consists of six registers with assigned 
functions. These are the 1 (Interrupt Register), 
the R (Refresh Register), the IX and lY (Index 
Registers), the SP (Stack Pointer), and the PC 
(Program Counter). The third group consists of 
two interrupt status flip-flops, plus an addi- 
tional pair of flip-flops which assists in identi- 
fying the. interfupt mode at any particular 
time. Table 1 provides further information on 
these registers. 
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Z80CPU 

(Continued) 
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Roglttw 


Six* (Bit*) 


A, A' 


Accumulator 
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F, F 


FlaijB 


8 


B. B- 


General Purpoae 


8 


C, C 


General Purpose 


8 


D, D- 


General Purpose 
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E, F 


General Purpose 
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H, H' 


General Purpose 


8 


L. L' 


General Purpose 


8 



I 




Interrupt Register 


8 


R 




Refresh Register 


8 


IX 




Index Register 


16 


lY 




Index Register 


16 


SP 




Stack Pointer 


16 


PC 




Program Counter 


16 


IFF, 


-IFFj 


Interrupt Enable 


Flip-Flops 


IMFa-IMFb 


Interrupt Mode 


Flip-Flops 



R*racDrks 

Stores an operand or the results o{ an operation. 

See Instruction Set. 

Can be used separately or as a 16-bit register with C. 

See B, above. 

Can be used separately or as a 16-bit register with E. 

See D, above. 

Can be used separately or as a 16-bit register with L. 

See H, above. 

Note: The (B,C), (D,E), and (H.L) seta are combined as follows: 
B — High byte C — Low byte 
D — High byte E — Low byte 
H — High byte L — Low byte 

Stores upper eight bits of memory address for vectored interrupt 
processing. 

Provides user-transparent dynamic memory refresh. Automatically 
iiK:remented and placed on the address bus during each 
instruction fetch cycle. 

Used for indexed addressing. 

Same as IX, above. 

Stores addresses or data temporarily. See Push or Pop in instruc- 
tion set. 

Holds address of next Inatniction. 

Set or reset to indicate interrupt status (see Figure 4). 

Reflect Interrupt mode (see Figure 4). 



Table 1. ZtO CPU Regliten 



Intarrupts: Th e CPU accept s two interrupt input signals: 

Ganeral NMI and INT. The NMI is a non-maska ble 

OpCTCrtlon interrupt and has the highest priority. INT is a 

lower priority interrupt since it requires that 
interrupts be e nable d i n so ftware in order to 
operate. Either NMI or INT can be connected 
to multiple peripheral devices in a wired-OR 
configuration. 

The Z80 has a single response mode for 
interrupt service for the non- mask able inter- 
rupt. The maskable interrupt, INT, has three 
programmable response modes available. 
These are: 

■ Mode — compatible with the 8080 micro- 
processor. 



■ Mode 1 — Peripheral Interrupt service, for 
use with non-8080/Z80 systems. 

■ Mode 2 — a vectored interrupt scheme, 
usually daisy-chained, for use with Z80 
Family and compatible peripheral devices. 

Th e C PU s ervices interrupts by sampling the 
NMI and INT signals at the rising edge of the 
last clock of an instruction. Further interrupt 
service processing depends upon the type of 
interrupt that was detected. Details on inter- 
rupt responses are shown in the CPU Timing 
Section. 



InlarmptK Hon-Mtmkabl* Interrupt (NMI). The non- 

G«n«ral maskable interrupt ojnnot be disabled by pro- 

Oparotlon gram control and thfrolo rg w ill be accepted at 

(Continued) at all limes by the CPU. FM is usually 

reserved for servicing only the highest priority 
type interrupts, such as that for orderly shut- 
down after power failur e has been detected. 
After rec ognition of the NMI signal (providing 
BUSREQ is not active), the CPU jumps to 
restart location 0066H. Normally, software 
starting at this address contains the interrupt 
service routine. 

Moskabl* Intsmrupt (Wf ). Regardless of the 
interrupt mode set by the user, the Z80 
response to a maskable interrupt input follows 
a common timing cycle. After the interrupt has 
been detected by the CPU (provided that 
interrupts are enabled and BUSREQ is not 
active) a special interrupt processing cycle 
begins . This is a special fetch (Ml) cycle in 
which lORQ becomes active rather than 
MREQ, as in^ normal Ml cycle. In addition, 
this sp ecial M l cycle is automatically extended 
by two WAIT states, to allow for the time 
required to acknowledge the interrupt request 
and to place the interrupt vector on the bus. 

Mod« Intsrrupt Operation. This mode is . 
compatible with the 8080 microprocessor inter- 
rupt service procedures. The interrupting 
device places an instruction on the data bus, 
which is then acted on six times by the CPU. 
This is normally a Restart Instruction, which 
will initiate an unconditional jump to the 
selected one of eight restart locations in page 
zero oi memory. 

Mode 1 Interrupt Operation. Mo de 1 o per- 
ation is very similar to that for the NMI. The 
principal difference is that the Mode 1 inter- 
rupt has a vector address of 0038H only. 
Mode 2 Interrupt Operation. This interrupt 
; . mode has been designed to utilize most effec- 
tively the capabilities of the Z80 microproc- 
essor and its associated peripheral family. The 
interrupting jperipheral device selects the 
starting address of the interrupt service 
routine. It does this by placing an 8-bit 
address vector on the data bus during the 
interrupt acknowledge cycle. The high-order 
byte of the interrupt service routine address is 
, supplied by the I (Interrupt) register. This flex- 
ibility in selecting the interrupt service routine 
address allows the peripheral device to use 
several different types of service routines. 
These routines may be located at any available 



location in memory. Since the interrupting 
device supplies the low-order byte of the 
2-byte vector, bit (Aq) must be a zero. 

Interrupt Priority (Daisy Chaining and 
Nested Interrupts). The interrupt priority of 
each peripheral device is determined by its 
physical location within a daisy-chain coniig- 
uration. Each device in the chain has an inter- 
rupt enable input line (lEI) aftd an interrupt 
enable output line (lEO), which is fed to the 
next lower priority device. The first device in 
the daisy chain has its lEI input hardwared to 
a High level. The first device has highest 
priority, while each succeeding device has a 
corresponding lower priority. This arrange- 
ment permits the CPU to select the highest 
priority interrupt from several simultaneously 
interrupting peripherals. 

The interrupting device disables its lEO line 
to the next lower priority. peripheral until it has 
been serviced. After servicing, its lEO line is 
raised, allowing lower priority peripherals to 
demand interrupt servicing. 

The Z80 CPU will nest (queue) any pending 
interrupts or interrupts received while a 
selected peripheral is being serviced. 

Interrupt Enable/Disable Operation. Two 

flip-flops, IFFi and IFFj, referred to in the 
register description are used to signal the CPU 
interrupt status. Operation of the two flip-flops 
is described in Table 2. For more details, refer 
to the Z80 CPU Technical Manual and Z80 
Assembly Language Manual. 



Action 



IFFi IFFj 



Comm*nl« 



CPU Reset 

DI instruction 
execution 

EI instruction 
execution 

,LD A, I instruction 
execution 

LD A,R instruction 
execution 

Accept NMI 



RETN instruction 
execution 



IFF 



IFFj 



Maskable interrupt 
INT disabled 

Mask able interrupt 
INT disabled 

Mask able interrupt 
INT enabled 

IFFj - Parity flag 
IFF2 - Parity flag 



IFF] - IFF2 
(Mas kabl e inter- 
rupt I!IT disabled) 

IFF2 - IFFi «t 
comp letion oi an 
NMI service 
routine. 
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TabU 2. Stcrt* oi FUp-Flop« 



InstTUctioii 



The Z80 microprocessor has one of the most 
powerful and versatile instruction sets 
available in any 8-bit microprocessor. It 
includes such unique operations as a block 
move for fast, efficient data transfers within 
memory or between memory and I/O. It also 
allows operations on any bit in any location in 
memory. 

The following is a summary of the 2B0 
instruction set and shows the assembly 
language mnemonic, the operation, the flag 
status, and gives comments on each instruc- 
tion. The Z80 CPU Technical Manual 
(03-0029-01) and Assembly Language 
Programming Manual (03-0002-01) coniain 
significantly more details for programming 
use. 

The instructions are divided into the 
following categories: 

D 8-bit loads 

D 16-bit loads 

D Exchanges, block transfers, and searches 

a 8-bit arithmetic and logic operations 

a General-purpose arithmetic and CPU 
control . 



D 16-blt arithmetic operations 

D Rotates and shifts 

D Bit set, reset, and test operations 

D Jumps 

a Calls, returns, and restarts 

D Input and output operations 

A variety of addressing modes are 
implemented to permit efficient and fast data 
transfer between various registers, memory 
locations, and input/output devices. These 
addressing modes include: 

D Immediate 

n Immediate extended 

D Modified page zero 

D Relative 

D Extended 

D Indexed 

D Register 

D Register indirect 

D Implied 

D Bit 
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16-Blt Load 
Group 
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LD dd, i«i dd — nn 

LD IX, nn IX - r>n 



LD IT, m lY - nn 



LDHL, (nn) H-(nn+I) 
L - (nn) 
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ddL — (nn) 
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Repeat until 
A » (HL) or 
BC = 



Q 

X X 1 



X X 



® ® 

I 1 X 1 X I 1 

® ® 

1 I X I X 1 1 



® © 

t I X 1 X 1 1 

® ® 

I t X t X > 1 



11 101 101 ED 
10 101 000 AS 



11 101 101 ED 
10 111 000 B8 



11 101 101 ED 
10 100 001 Al 



11 101 101 ED 2 
10 110 001 Bl 2 



11 101 101 ED 2 
10 101 001 A9 



11 101 101 ED 2 
10 111 001 B9 2 



21 II BC » 

16 11 BC = 



II BC # and 
A * (HL) 

II BC > or 
A = (HL) 



If BC * and 
A * (HL) 

II BC = or 
A = (HL) 



NOTES: (t) P/V tUq in il lh« twiuH o( BC - 1 =0, othorwiee P/V = 1 . 
(3) Z ilaq m 1 if A :» (HL), o!h«rwt«i Z = 0, 



8-Blt 


ADD A, r 


A - A + r 


Arlthmatlc 


ADD A. n 


A — A + n 


nnd Logical 






Group 


ADD A, (HL) 


. A - A ■!■ (HL) 




ADDA, (IX + 


d) A - A + (IX + d) 




ADDA, (IY + 


d) ft- A + (lY+d) 




ADC A, = 


A-A + . + CY 




SUB 3 


A - A-. 




SBC A, « 


A - A-I.-CY 




ANDs 


A - A A . 




OH. 


A - A V , 




XOH« 


A - A • «, 


' 


CP. ■ 


■ A-. 




IMCr 


f - r ♦ I 




INC (HL) 


(HL)-(HL)*1 




INC(IX+d) 


(IX + d) - 
(IX+di+l 




, INC(IY>d)■ 


iiYtd)- 
, (iy + d)+l 



XV 

X V 



lopng 



loiroiiio 
11 on 101 

10^110 

- d - 
II 111 lOI 

loBSauo 

- d - 



X 1 


X 


V 





I 


(Mil 


X 1 


X 


V 


1 


1 


Eg 


X 1 


1 X 


V 


1 


1 


Efl 


X 1 


1 X 


p 








iroa 


X X 


p 





. 


lira 


X X 


p 








DSD 


X 


1 X 


V 


1 


I 


DU 


X 


1 X 


V 





« 


00 r CSl 


X 


1 X 


V 





. 


00 iloQSI 


X 


1 X 


V 







II on 101 

00 110(0 
-ri- 


X 


1 X 


V 





" 


ll III 101 

00 iioro 



nsi 



II 

23 



Reg, 



2 


2 


7 


000 B 

001 C 
010 D 


1 


■ 2 


7 


<ni e 


3 


S 


19 


100 H 

101 L 
III A 



s ia any of r, n, 
(HL), aX + d), 
{lY+d) as shown 
for ADD inrtrudion. 
The indicated biln 
raplace the \fX)C^ in 
the ADD Bet above. 



n iB any at t. (HU. 
(IX + d). (lY + d) 
as shown (or INC. 
DEC same (onnat 
and stales as INC. 
Replace (IS with 
n^n In opcode. 
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GsiMial- 

ArilhiMtic t"** 

and 

CPU Control 

GSronpa cfl 

HEG 

CCT 

SCF 
HOP 
HALT 

m» 
a* 

MO 
IMI 



FHaVB 



Inlo pKlMl BCD 
iolkmlltq add or 
■ubmct wtlh packwl 
BCDo 
A- I 



A ~ - A 
CT -EY 



X I X P 



CY - 1 

HoepmrMon 

CPUh«ll«l 

IFF-0 

lFF-1 

S«tintafnip4 

mbdeO 
S«4 intoTTupt 

Set littaiiup4 

WMJdU A 



00 100 III 


n 


1 


1 


4 


DKlMladHd 


00 101 III 


JF 


1 


1 


4 


CcnpiaMM 
aocumuUtor (ofM'e 


II 101 101 


ED 


3 


2 


8 


Nagda aoc. (Mo'a 


01 000 100 


M 








coaplatMid). 


00 III 111 


3F 


1 


1 


4 


ComplaflMnl OWTT 
ll«>. 


00 110 111 


37 


1 


1 


4 


SatcarnrlU^. 


00 000 000 


00 


1 


1 


4 




01 no no 


76 


1 


1 


4 




11 no on 


F3 


1 


1 


4 




11 111 on 


FB 


1 


1 


4 




II 101 101 


ED 


2 


2 


e 




01 000 no 


« 










II 101 101 


ED 


3 


2 


a 




01 010 no 


» 










11 101 101 


ED 


3 


3 


8 




01 on no 


SE 











or 



tlwMfnrfltp-IUip. 

mit»m 



IB-Blt 
Jtiritlunotk: 

UrfOUp 



ADD HL. » HL - 

ADC HL. •> HU - 



HLtM 
HLi-M^CY 



SBCHL. ■ HL-HL-M-CY 
ADD U. pp IX - IX f PC 



XXX 

XXX 

XXX 
XXX 



mc« 

INC IX 


■•- « + 1 
IX- IX t 1 


INCIY 


lY - lY + 1 


DECn 
DECK 


m - Ji-l 
IX- IX- 1 



• X . X 

• X » X 



• X • X 

• X » X 



00 al 001 

11 101 101 

01 ml 010 


ED 


I 
2 


3 

4 


11 
15 


00 EC 

01 DE 
10 HL 


11 101 101 


ED 


2 


4 


IS 


11 SP 


01 uO 010 












11 on 101 

01 ppl 001 


DD 


2 


4 


IS 


01 DE 
10 IX 


11 in 101 

00 rrl 001 


FD 


3 


4 


IS 


11 SP 
rr Beg. 

01 vz 

10 lY 


00 nOOll 




1 


1 


6 


11 SP 


11 on 101 


DD 


2 


2 


10 




00 100 oil 


23 










II in 101 


FD 


2 


2 


10 




00 100 011 


23 










ooa.1 on 




1 


I 


6 




n on 101 


DD 


2 


t 


10 




00 101 on 


2B 










U 111 101 


FD 


2 


1 


10 




oo 101 on 


2B 














NOTES: MMARrdttMntqiMriMtnBC. D£. HI.. SP. 
pp If Any et ih« ragiMcf p«ira BC. DE. IX. SP. 
rns any Hi Ih* raqiitor pairs BC. DE. lY. SP- 



Hotate ond 
Shift Gratqp 




nLC(IT«d) 



I X X - p I 



I ! X X P 



X X P I 



SLm Lgg 1 , — gJ , , 

<liair.(HLMIX»dl.(IY«'d) 

BBCm M T. « |-^[g] I I X X P I 

n-t.lHU.dXa-dl.lIYa'd) 



00000 111 07 



00 010 111 12 



00 001 111 OF 



00 Oil 111 IF I 

II 001 on CB 2 

00 OW r 

II 001 on CB 2 

00 000 110 

li on 101 DD 4 

II 001 on CB 

- d - 

00 oDO no 

11 111 101 FD 4 

II 001 on CB 

- d - 
00 000 no 

010 



Botata latl circular 
accumuuitor. 

BotalA Ml 
accunuiiator. 

Botata nght circular 
accumulator. 

Botata nqhl 
accumulator. 

Botata lalt circular 
reqiitar r. 



000 
001 
010 

on 

100 
101 

111 



Ifulructioti format 
and slalaa ara aa 
shown lor BLCa. 
To lorffl mm 
opcoda (aplaca 
000 or BLCa 
with ahown code. 
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Botota and 
Shift Group 

(Continued) 



gynboUc 



S Z 






m»r.(HU.(IX-l-dl.(lY»d) 



fcrl - 1 7- — n} ~« 

n>-r,(HL).(IX + d),(lY*d) 

[— I _' — -° I — -dil 

ni-.r.(HL).IIX + d).(IY + d) 



» H ' — ° I (13 

m«r.(HL),(lXi-d).(IY + d) 



I 1 X X P 1 

I I X X P I 

1 I X X P I 

1 t X X P 1 



m 



\t-A]3-«\ |' -<|J-l>| 1 I X X P 

A tMLt 



ED 




rrm 




11 101 101 


ED 


01 101 HI- 


6F 



I — —\l — i 

\T-i\3-o\ H7-<|1-0| I ! X X P • 11 101 101 ED 

1 I ■ 01 100 111 67 



le Rotete digit iett and 

right between 
the eccumulalor 
and location (HL). 

16 The content ol the 
upper half ol 
the accumulator is 
unaffected 



Bit Si»t. Ramit bit b, r z - ib 
and Test b„ ^^ ,ny z - iHLib 
Group 

BITb. (IX+d)b Z- (IX4-d)b 



BITb. (lY-t-dlb Z- (lYtdlb 



X 1 X 1 X X 
X 1 X 1 X X , 
X I X 1 X X 



SET b, r rb ~ 1 

SETt. (HLl (HL)b - 1 

ShTb, (IX + d) (lX + d)b - 1 

' SETb, (lYtd) (lYtdlb - 1 



X I X 1 X X 



X ■ X 
X • X 
X " X 



n 001 on CB 

01 b r 

11 001 oil CB, 

01 b no 
II on 101 DO 
n 001 on CB 

- d - 

01 b no 

n 111 101 FD 

II 001 on CB 



11 ooj on CB 
CD b ' 
n 001 oil CB 
n b no 

11 oil 101 DD 

n 001 oil CB 

- d - 

in b '10 

II in 101 FD 
11 001 oil CB 

- d - 
[Q b 110 



f Bea: 

ISM B 

XI c 

010 D 

on E 

100 H 

lor L 

111 A 

b Bit Teated 



OOO 

001 
010 

on 

100 
101 

no 
111 



IS 
23 





RES b, m 


mb - 

m « r. (HL), 
(IX + d), 
(IY*d) 


• • X 




X 




m 










To lortn new 
opcode replace 
(ni ol SET b, . 
With 0. Flag. 
and time atatea lor 
SET inatfuction. 




NOTES; th* notation mt indicaics bit b (0 


lo 7) or iocfllfon 


. 


















Inmp 


IPnn 


PC - nn 


■ " " X 


. 


X 


,, . . 


II OOO oil 


C3 


3 


3 


' 10 




Group 


IPcc. nn 


H condition cc la 


• • X 


» 


X 


ffl A 1) 


— ri- 
ll cc 010 




3 


3 


10 


cc Condition 


OQO N2 non-xero 






true PC - nn, 










- n — 


























— n — 










010 NC nonom 






continue 




















on C carrr 

100 PO putty odd 

101 PE parity even 
1,10 P «Kjli poaiti™ 




IRe 


PC - PC»e 


• " X 


" 


X 


" " " 


00 on 000 


IB 


2 


3 


12 


HI M •iflnn«)aU«i 




IHC. e 


lie . 0. 

continue 

lie » 1, 


• » X 


a 


X 


a fli n 


00 inooo 

■- e-J. - 


» 


1 

2 


2 
^ 3 


7 

12 


H condition not m«, 
11 condition IS met. 




)R NC, • 


PC - PC+e 
II C " 1 . 
continue 
II C » 0, 


• • X 


a 


X 


, . . 


00 no oeo 

- e-3 - 


30 


2 

■ 2 : 


2 

3 


f 
12 


If condition'not o>et. 
II condition la met. 




IPZ, e 


PC - PC*« 
II Z . 
continue 
112 - 1. 


• «■ X 


• 


X 


. . .■■ 


00 101 OOO 

- e-2 -■ 


» 


2 

2 


2 
,3 


7 

12 


II condition not mart. 
II condition li met. 




IR NZ, • 


PC - PC + e 
HZ . 1. 
continue 
II Z - 0, 
PC - PC*e 


» • X 


• 


X 


* o n 


00 100 000 

- 0-2 - 


20 


2 
2 


2 
3 


7 
12 


II condition not met. 
11 condition ii mel. 




JP (HU 


PC - HL 


« •; X 


• 


X 


a 9 e> 


II 101 IX)1 


E» 


1 


1 








IP (IX) 


PC - IX 


• " X 




X 


o " « a. 


11 on 101 
n 101 001 


DD 
E9 


2 


3 


e 





Iwcap Gfonp 

(Continued) 



n»m 



U»M UmMM W»MT 

tR 149 SU MWI WytM CfCiM WMMi 



ip(m 

DINZ. « 



B - B-l 
liB - 0. 



n HI 101 FD 
II 101 001 IS 

00 010 000 10 

— «-2 x~ 



liB»0. 

PC - PC*« 



NOTES: » nprmtMt llM mmoMoa In Ih* mUllM «ddMMliig Mod*. 

a la n «Kwd two'i lAMHj Uiwi il twimb^r In thranq* < -13S. 129>. 
a - a In Iha opcoda pravldaa an atfactltfa addraai ol PC « a aa PC is Ineraatan^d 
br a prior to Iha addUMn ol a. 



Ratura Group 


CALLm 


(SP-D-PCh 
(SP-2) - PCl 
PC -cm 




CAUcc, nil 


BooiKlmon 

cciaiolM 

oontiniM, 

CALLim 




RET 


PCl.-(SP> " 
PCh-(SP*I) 




RETcc 


Uc(3ndiUon 

ccuhlaa 

conUnua. 

atfnnm 

aanwAC 

BET 




SETI 
HETN! 


Ratumtram 

Ratura inm 

non-nukabU 

Intamipl 




RSTp 


(SP-D-PCh 
(SP-2) - PCl 
PCh-0 
PCl-p 



a • X « X 



■ • % • % 
a X " X 



11 001 101 CD 



II cclOO 

— n — 



II 001 001 C9 1 

II ccOOO 1 

1 



II 101 101 ED 

01 001 101 4D 

II 101 101 ED 

01 000 101 45 



10 U oc la iaiaa. 
17 U cc ia Iru*. 



oc Condition 


MtK noni«o 


OOl Z wo 


010 NC ma-oarry 


Oil C catfT 


100 PO parltr odd 




nop Ugnpoaltlva 


HI M itgnnawuin 
t c 


o66 m 


001 OBH 


010 lOH 


on I8H 


m 20H 


101 28H 


no 30H 


HI 3eH 



I 



NOTE. 'REIN loadr IFFj - IFF| 



Input and m a. m 
Output Group „,^,c) 



nn 
mm 

IND 

mDR 

OUT (n). A 
OUT (C). r 

OUTI 

OTIH 



r-(C) 

lit < 110 only tha 

flag* win be affactad 

(HL) - (C) 

B-B-1 
HL - HL •!■ 1 
(HU - (C) 
B-B-1 
HL - HL * 1 
Repaat until 
B . 

(HU - (C) 
B-B-1 
HL-HL-I 
(HU - (C) 
B-B-1 
HL- HL-I 
RapMt until 
B - 
M - A 

(C) - r 



(C) - (HL) 
B - B-l 
HL - HL ♦ 1 
(C) - (HU 
B- B-l 
HL - HL * 1 
Rapeat until 



(C) - (HU 
B- B-l 
HL- HL-l 



X • X » a 

X 1 X P 



® 



X 1 X X X X 1 

X IX X X X 1 

CD 

X I X X X X I 

X I X X X X I 



• X 

• X 



X " 

X » 



® 



X I X X X X I 



X I X X X X I 



® 

X I X X X X I 



II on oil DB 



II 101 101 ED 

01 r ixn 



11 101 101 ED 
10 100 010 A2 



II 101 101 ED 
10 no 010 B2 



II 101 101 ED 
10 10! 010 AA 



II 101 101 ED 
10 111 010 BA 



II 010 Oil D3 



11 101 101 ED 
01 r 001 



II 101 101 EO 
10 100 011 A3 



11 101 101 ED 

10 noon B3 



11 101 101 ED 2 
10 101 Oil AB 



5 
(II B«0) 



(IIB-01 



S 
(li B#0) 

4 
(It B-0) 

3 

3 



(It B«01 

4 
(IIB-O) 



11 
12 



21 

le 



n to Ao ~ A7 
Ace. to A^ - Ai5 
C to Ao ~ A7 
BtoAs - Ai5 



CloAo - A7 
BtoAfl - A|5 



C to Ao - A7 
BtoAa - Ais 



C to Ao - A7 
BtoAa - A|5 



C to Ao - A7 
B to Aa - Ai5 



n to Ao - A7 
Ace. to Afl - A|5 
C to Ao - A7 
B to Ae - A|5 

C to Ao - A7 
BtoAe - A|S 

C to Ao - A7 ■ 
B to Ae - Ais 



C to Ao - A7 
BloAg - Ai5 



NOTE: ^ If tiM (aflutt ol B - ) i« Mro lha Z llaq <a Mt. athmrmm it in nMitt. 



2(X)1-001 



Input (md 
Output Group 

(Continued) 









n S49 »0 Bas lyMa Cfctea SUM 



HL - IIL - 1 
RopMt until 
B = 



X I X X X X 1 



II 101 101 ED 

10 111 on 



5 
(IIB»0) 



C to Aq - A7 
B to As - Ai5 



SuxDmary oi 
Opwrotloci 






c 



ADD A. .; ADC A, . 

SUB »; SBC A, n: CP .; HEG 

ANDu 

OR «, XOH s 

INCi> 

DEC« 

ADD DD, n 

ADC HL, m 

SBC HL. n 

RLA, HLCA, RRA: RRCA 

HL m; RLC m; RR m; 

HRC m; SLA m; 

SRA m; SRL m 
RID; RRD 
DAA 
CPL 
SCF 
CCF 
IN r (C) 

INI, IND. OUTi; OUTD 
INIH; INDH: OTIH; OTDR 
LDI; LDD 
LDIR: LDDR 
CPl: CPIR; CPD; CPDR 

LDA. 1, LDA,R 
BITb, » 



8-bit add or add with carry. 

9-bit nubtract, subtract with carry, compare and n«qate accumulator. 

Logical oporationa 
8-bii increment. 
8-bit d«cremont. 
16-bit add. 

16-btt add with carry. 
16-bit nubtract with carry. 
Rotate accumulator. 
Rotate and shift locations. 



Rotate digit left and right. 
Decimal adjust accumulator. 
Complement accumulator. 
Sot carry. 
Complement carry. 
Input register indirect. 

Block input and output. Z = 



if B A otherwise Z = 



X IFF 
X X 



Block tranalerinsinictiom. P/V . 1 if BC * 0, otherwise P/V « 0. 

Block search instructions. Z = 1 if A = (HL), otherwise Z = 0. P/V = 1 

if BC * 0, otherwise P/V « 0. 
The content of the interrupt enable flip-flop (IFF) is copied into the P/V Hag. 
The state of bit b ol location a is copied into the Z flag. 



SymboUc Symbol Operation 

Notation S Sign (lag. S = 1 if the MSB ol the result is 1 . 

Z Zero flag. Z = I if the result of the operation is 0. 

P/¥ Parity or overflow flag. Parity (P) antJ overflow 

(V) share the same flag- Logical operations affect 
this flag with the parity of the result while 
arithmetic operations affect this flag with the 
overflow of the result- If P/V holds parity, P/V = 
1 if the result of the operation is even, P/V = if 
result is .dd- If P/V holds overflow, P/V = 1 if 
the resu- ■ the operation produced an overflow. 

H Half-cat i- lag. H = 1 if the add or subtract 

operatio •.-.•oduced a carry into or borrow from 
bit 4 of '.■■■ accumulator. 

W Add/Su' ■ ict flag. N = 1 if the previous opera- 

tion was -.ubtract. 

H & N H and K .gs are used in conjunction with the 

decimal ' 'ist instruction (DAA) to properly cor- 
rect the .It into packed BCD format following 
flidditior subtraction using operands with 
packed I .) format. 

C Carry/Li flag. C = 1 if the operation prixiuced 

a carry f . -n the MSB of the operand or fesult. 



Symbol 

t 



Oporailon 

the flag is affected according to the result of the 

operation. 

The flag is unchanged by the operation. 

The flag is reset by the operation. 

The flag is set by the operation. 

The flag is a "don't care." 

P/V flag affected according to the overflow result 

of the operation. 

P/V flag a<fected according to the parity result of 

the operation. 

-A;iy one of the CPU registers A, B, C, D, E, H, L. 

Any 8-bit location for all the addressing modes 

allowed for the particular instruction. 

Any 16-bit location for allthe addressing modes 

allowed for that instruction. 

Any one of the two index registers IX or lY. 

Refresh counter. 

8-bit value in range < 0. 255 > . 

16-bit value in range < 0, 65535 > . 
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Pin Ag-Ais. Address Bus (output, active High, 

Dascriptioix 3-state). A0-A15 form a 16-bit address bus. The 
Address Bus provides the address for memory 
data bus exchanges {up to 64K bytes) and for 
I/O device exchanges. 

BUSACK. Bus Acknowledge {oulpnt, active 
Low). Bus Acknowledge indicates to the 
requesting device that the C PU add r ess bus , 
data bus, and control signals MREQ, lORQ, 
RD, and WR have entered their high- 
impedance states. The external circuitry 
can now control these lines. 



BUSREQ. Bus Request (input, active L ow). 
Bus Request has a higher priority than NMI 
and is always recog nized at th e end of the cur- 
rent machine cycle. BUSREQ forces the CPU 
addres s bus, d ata bus, and control signals 
MREQ, lORQ, RD, and WR to go to a high- 
imp>edance state so that othe r devices can 
control these lines. BUSREQ is normally wire- 
ORed and requires ah extern al pullup for 
these applications. Extended BUSREQ 
periods due to extensive DMA operations can 
prevent the CPU from properly refreshing 
dynamic RAMs. 

D0-D7. Data Bus (input/output, active High, 
3-state). D0-D7 constitute an 8- bit bidirectional 
data bus, used for data exchanges with . 
memory and I/O. 

HALT. Halt State (output, active Low). HALT 
indicates that the CPU has executed a Halt 
instruction and is awaiting either a non- 
maskable or a maskable interrupt (with the 
mask enabled) before operation can resume. 
While halted, the CPU executes NOPs to 
. maintain memory refresh. 

INT. Interrupt Request (input, active Low). 
Interrupt Request is generated by I/O devices. 
The CPU honors a request at the end of the 
current instruction if the internal software- 
controlle d int errupt enable flip-flop (IFF) is . 
enabled. INT is normally wire-ORed and 
requires an external pullup for these 
applications. 

lORQ. Input/ Outpu t Request (o\i\pu\, active. 
Low, .3-state). lORQ indicates that the lower 
half of the address bus holds a valid I/O 
addre ss for an I/O read or write operation. . 
lORQ is also generated concurrently with Ml 
during an interrupt acknowledge cycle to indi- 
cate that an interrupt response vector can be 



placed on the data bus. 

Ml . Machine Cyc le One (output, active Low). 
Ml, together with MREQ, indicates that the 
current machine cycle is the opcode fetch 
cycl e of an instruction execution. Ml, together 
with lORQ, indicates an interrupt acknowledge 
cycle. 



MSiEQ. Mem ory Req uest (output, active 
Low, 3-state). MREQ indicates that the address 
bus holds a valid address for a memory read or 
memory write operation. 

NMI. Non- Maskable Interrupt (input, acti ve 
Low). NMI has a higher priority than INT. NMI 
is always recognized at the end of the current 
instruction, independent of the 
status of the interrupt enable flip-flop, and 
automatically forces the CPU to restart at 
location 0066H. 

HD. Memory Read (output, active Low, 
3-state). RD indicates that the CPU wants to 
read data from memory or an I/O device. The 
addressed I/O device or memory should use 
this signal to gate data onto the CPU data bus. 



RESET. i?ese/ (input, active Low). RESET 
initializes the CPU as follows: it resets the 
interrupt enable flip-flop, clears the PC and 
Registers I and R, and sets the interrupt status 
to Mode 0. During reset time, the address and 
data bus go to a high-impedance state, and all 
control o utput si gnals go to the inactive state. 
Note that RESET must be active for a minimum 
of three full clock cycles before the reset 
operation is complete. 



RFSH. Refres h (outp ut, active Low). RFSH, 
together with MREQ, indicates that the lower 
seven bits of the system's address bus can be 
used as a refresh address io the system's 
dynamic memories. 



WAIT. Wait (input, active Low). WAIT 
indicates to the CPU that the addressed mem- 
ory or I/O devices are not ready for a data 
transfer. The CPU continues to enter a Wait 
state a s long as this signal is active. Extended 
WAIT periods cari prevent the CPU from 
refreshing dynamic memory properly. 

WR. Memory Write (output, active Low, 
3-state). WR indicates that the CPU data bus 
holds valid data to be stored at the addressed 
rnemory or I/O location. 
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CPU Timing The Z80 CPU executes instructions by pro- 

ceeding through a specific sequence o< opera- 
tions: 

■ Memory read or write 

■ I/O device read or write 

■ Interrupt acknowledge 



The basic clock period is referred to as a 
T time or cycle, and three or more T cycles 
make up a machine cycle (Ml, M2 or M3 lor 
instance). Machine cycles can be extended 
either by the CPU automatically inserting one 
or more Walt states or by the insertion of one 
or more Walt states by the user. 



Instruction Opcode Fetch. The CPU places 
the contents of the Program Counter (PC) on 
the address bus at the start of the cycle (Figure 
5). Ap proximately one-half clock cycle later, 
MREQ goes active. The falling edge of MREQ 
can be used directly as a Chip. Enable to dyna- 
mic memories. When active, ,RD indicates that 
the memory data can be enabled onto the CPU 



data bus. 

The CPU samples the WAIT input with the 
rising edge of clock state T3. During clock 
states T3 and T4 of an Ml cycle dynamic RAM 
refresh can occur while the CPU starts 
decoding and executing the instruction. When 
the Refresh Control signal becomes active, 
refreshing of dynamic memory can take place. 



»»sn 




-^ETIZXEEX 



R^H 



-if- 



1 



KJ) 



-r® 



J 



NOTE: T^-Wail cycle added when necessary for slow ancilliary devices. 

FIgtiT* S. fawtractlon Opcod* Fateh 
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CPU Mamory Read or Writ* Cycla*. Figure 6 

Timing shows the timing of memory read or write 

(Continued) cycl es othe r than an opcode fetph (Ml) cycle. 
The MREQ and RD signals Junction exactly as 
in the fetch cycle. In a memory write cycle, 
MREQ also becomes active when the address 



bus is stable, so that it can be used directly as 
a Chip Enable for dynamic memories. The WR 
line is active when the data bus is stable, so 
that it can be used directly as an R/W pulse to 
most semiconductor memories. 



T, Tj 



-K<>*- 



iiS 



RSAD ; 



(D*! 



U-® 



-■"" !^ 



wS 



KD 



1 



a 



-^ 



^. 



-^I 




-/^ — 

VALID ADDRESS 

-*•/ 



ifj 




u 



-y/- 



iT/- 






-f/- 



~(f- 



-f/- 



-ff- 



®*- 




®-^ 



® 



% 



\ ' VALID ' J' 
/ r DATA . ^ 



I*® 



^ 



-*l® 



H®- 



-if- 



-tf- 



/ 



® 



/5 -___ ,-.,__ 



n 

o 



® 



-^j~ 
-/f- 



Flgura 6. Mmnory Read or WrlMCycla* 
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CPU Input or Output Cycles. Figure 7 shows the 

Timing timing for an I/O read or I/O write operation. 

(Continued) During I/O operations, the CPU automatically 



inserts a single Wait state (T„). This extra Wait 
state allows sufficient time for an I/O port to 
decode the address and the port address lines. 
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NOTE: T„-= One Wait cycle automatically Inserted by CPU. , 

Figure 7. Inpun or Output CyclM 



Interrupt Request/ Acknowledge Cycle. The 

CPU samples the interrupt signal with the ris- 
ing edge of the last clock cycle at the end of 
any instruction (Figure 8). When an interrupt 
Is accepted, a special Ml cycle is generated. 



During thi s Ml cyc le, lORQ becomes active 
(instead of MREQ) to indicate that the inter- 
rupting device can place an 8-bit vector on the 
data bus. The CPU automatically adds two 
Wait states to this cycle. 
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CPU Non- Magkabl« Intarrupt Ra<iua8t Cycle. 

Timing NMI is sampled at the sa me t ime as the 

(Continued) maskable interrupt input INT but has higher 

priority and cannot be disabled under software 
control. The subsequent timing is similar to 



that of a normal memory read operation except 
that data put on the bus by the memory is 
ignored. The CPU instead executes a restart 
(RST) operation and jumps to the NMI service 
routine located at address 0066H (Figure 9). 
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'Although NMI is an asynchronous input, to guara ntee its being 
recognized on the loHowing machine cycle, NMI's lalling edge 



must occur no later ;. :he rising edge oi the clock cycle 
preceding TlasT- 



Figure 9, Non-Maskable Interrupt Request Op ton 



Bub Request/Acknowledge Cycle. The CPU 

samples' BUSREQ with the rising edge of the 
last cl ock period of any machine cycle (Figure 

10). If BUSREQ is active, t he CP U sets its 

address, data, and MREQ, lORQ, RD, and WR 



lines to a higl pedance state with the rising 
edge of the ne .lock pulse. At that time, any 
external devici ..an take control of these lines, 
usually to transier data between memory and 
I/O devices. 



NOTE: Tl= Last state of any M cycle. 




Tx= An arbitrisry clock cycle used by lequesting device. 
Figui* 10. Buc HMpiaM/Acknowladga Cycl* 
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Halt JlcknowWfl* Cyd*. Wh«»n the CPU roortved. When to the Halt ttate, the HALT 

^ receives a EKLT instruction, it execute* NOP output i« active and reinaln* so until an inter- 

(Continued) states until either an INT or HRI input is rupt U proce«fed (Figure 11). 
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NOTE: INT will nl«o force a Hall exit. 



sU 

*Se« note, Figure 9. 
Figur* U. Halt Acknowlsdg* Cycl« 



Reset Cycle. RESET must be active for at least inactive, two internal T cycles are consumed 

three clock cycles fo r the CP U to properly before the CPU re sumes normal processing 

accept it. As long as RESET remains active', the operation. RESET clears the PC register, so the 

address and data buses flo at, and the control first opcode fetch will be to location 0000 

outputs are inactive. Once RESET goes (Figure 12). 
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AC 








ZW'CPO 
Min Max 


Z80ACPU 
Mln Max 


Z80BCPU 
Mln Max 


tmistics 


Humlxnr 


Symbol 


PorcmMtat 


{n«) ; 


(»■) 


(m) 


(M) 


(oB) 


(M) 




1 


TcC 


Clock Cycle Time 


400* : 




250* 




165* 






2 


TwCh 


Clock Pulse Width (High) 


180-: 




110* 




65* 






3 


TwCl 


Clock Pulse Width (Low) 


180 , : 


2000 


110 


2000 


65 


2000 




4 


TfC 


Clock Fall Time 


r-' - 


3Q 


— 


30 


— 


20 




5 — 


-TrC 


-Clock Rise Time - 
















6 
7 


TdCr(A) 
TdA(MREQf) 


Clock 1 to Address Valid Delay 


125* 


145 


65* 


110 


35* 


90 




Address Valid to MREQ 
I Delay 


~ 




8 


TdCf(MREQl) 


Clock 1 to MREQ 1 Delay 


- 


100 


- 


85 


- 


70 




9 

lo- 
ll 
12 


TdCr(MREQr) 

- TwMREQh 

TwMREQl 
TdCl(MREQr) 


Clock ! to MREQ t Delay 


— 


100 


— 


85 


— 


70 




- MREQ Pulse Width (High) 


360* 


100 


220* 


85 


135* 






MREQ Pulse Width (Low) 


- N 




Clock 1 to MREQ t Delay 


70 g 




13 


TdCf(RDf) 


Clock 1 to RD 1 Delay 


- ' 


130 


- 


95 


- 


80 rt 




14 


TdCr(RDr) 


Clock t to RD 1 Delay 


— 50- 


100 




85 


in 






















16 

17 


ThD{RDr) 
TsWAIT(Cf) 


Data Hold Time to RD 1 


70 





70 





60 


. 




WAIT Setup Time to Clock 1 


— 




18 


ThWAIT(Cf) 


WAIT Hold Time after Clock 1 


— 





— 





- 







19 


TdCr(Mlf) 


Clock t to Ml I Delay 


- 


130 


— 


100 


— 


80 




20 — 


— TdCr(Mlr) 


















21 


TdCr(RFSH{) 


Clock 1 to RFSH I Delay 


— 


180 


— 


130 


- 


110 




22 


TdCr(RFSHr) 


Clock 1 to RFSH t Delay 


— 


150 


- 


120 


— 


100 




23 


TdCKRDr) 


Clock I to RD 1 Delay 


— 


110 


- 


85 


- 


70 




24 


TdCr(RDf) 


Clock t to RD 1 Delay 




100 




85 




70 




26 

27 


- 1 sDCCl) - - 

TdA(IORQf) 
TdCr(IQRQf) 


Mj, M3, M4 or Ms Cycles 


320* 


90 


180* 


75 


110* 






Address Stable prior to lORQ i 


. — 




Clock 1 to lORQ 1 Delay 


65 




28 


TdCf(IORQr) 


Clock I to lORQ I Delay 


— 


110 


- 


85 


- 


70 




29 


TdD(WRf) 


Data Stable prior to WR 1 


190* 




80* 




25* 






30- 


TdCi(WRf) 


















31 


TwWR 


WR Pulse Width 


360* 


— 


220* 


- 


135* 


- 




32 


TdCf(WRr) 


Clock 1 toWR I Delay 


— 


100 


— 


80 


- 


70 




33 


TdD(WRf)' 


Data Stable prior to WR 1 


20* 


— 


-10* 


— 


-55* 


- 




34 


TdCr(WRf) 


Clock t to WR 1 Delay 


- 


80 


60* 


65 


in* 


60 




36 


— TdWRr(D) 

TdCf(HALT) 






300 


300 








Clock 1 to HALT 1 or i 


260 




37 
38 


TwNMI 
TsBUSREQ(Ci 


NMI Pulse Width 


80 
80 


- 


80 
SO 


- 


70 
50 


— 




) BUSREQ Setup Time to Clock I 


— 



"For clock periods other than the minimums shown in the table, 
calculate parameters usinq the expressions in the table on the 
following page. 



AC 

Chairac- 
tarlstlcs 


NumbtM 


Symbol 


Potranuitar 


Z80CPU 
Mln Max 

(M) (lU) 


Z80ACPU 
Mln Max 

(ni) (M) 


Z80BCPU 
Mln Max 

(na) (m) 


(Continued) 


39 


ThBUSREaCr) 
-TdCr(BUSACKf)' 
















BUSREQ Hold Time after Clock ! 
-Clock 1 to BUSACK 1 Delay 


- 


















41 


TdCf{BUSACKr) 


Clock 1 to BUSACK 1 Delay 


— 


no 


- 


100 


- 90 




42 


TdCr(Dz) 


Clock 1 to Data Float Delay 


— 


90 


— 


90 


- 80 




43 


TdCr(CTz) 


Clock I to Control Outputs Float 


~ 


no 


~ 


80 


— 70 




DelajiJMREQ, lORQ, RD, 
and WR) 






44 
45 — 

46 


TdCr(A2) 


Clock t to Address Float Delay 


-160*- 
90 


no 




90 


- 80 




TsRESET(Cr) 


lORQ t, RD l.andWR t 




60 








RESET to Clock t Setup Time 


60 - 




47 


ThRESET(Cr) 


RESET to Clock 1 Hold Time 


— 





— 





- 




48 


TsINTf(Cr) 


iNT to Clock 1 Setup Time 


80 


— 


80 


— 


70 — 




49 
50- 


ThlNTr(Cr) 
-TdMlf(IORQf) — 


iNT to Clock t Hold Time 












— 


















51 . 


TdCf(IORQf) 


Clock I to lORQ I Delay 


— 


no 


— 


85 


— 70 




52 


TdCf(IORQr) 


Clock t to lORQ 1 Delay 


— 


100 


— 


85 


- 70 




53 


TdCf(D) 


Clock 1 to Data Valid Delay 


— 


230 


- 


150 


- 130 



"For clock periods other than the minimums shown in the table, 
calculate parameters using the followinq expressions. Calculated 
values above assumed TrC = TfC = 20 ns. 



Footnotes to AC Charactsristics 



Number Symbol 



280 



zaoA 



Z80B 



1 


TcC 


TwCh + TwCl + TrC + 


TfC 


TwCh + TwCl + TrC + 


TfC 


TwCh + TwCl + TrC + TIC 


2 


TwCh 


Although static by design 
TwCh o( greater than 200 
is not guaranteed 


lis. 


Although static by design 
TwCh of greater than 200 
is not guaranteed 


(IS 


Although static by design, 
TwCh of greater than 200 jis 
is not guaranteed 


7 — 


- TdA(MREQ() - 






- TwCh + TfC - 65 












10 


TwMREQh 


TwCh + TfC - 30 




TwCh + TfC - 20 




TwCh + TfC - 20 


11 


TwMREQl 


ToC - 40 




TcC - 30 




TcC - 30 


26 


TdAdORQl) 


TcC - 80 




TcC - 70 




TcC - 55 


29 
2\~ 


TdD(WRi) 


TcC - 210 




TcC - 170 




TcC - 140 














33 


TdD(WRf) 


TwCl + TrC - 180 




TwCl + TrC - 140 




TwCl + TrC - 140 


35 


TdWRr(D) 


TwCl + TrC - 80 




TwCl + TrC - 70 




TwCl + TrC - 55 


45 


TdCTr(A) 


TwCl + TrC - 40 




TwCl + TrC - SO 




TwCl + TrC - 50 


.50' 


TdMlKIORQf) 


2TcC + TwCh + TIC - 


SO 


2TcC + TwCh + TfC - 


65 


2TcC + TwCh + TfC - 50 



AC Test Conditions: Vqh = 2.0 V 

V,H = 2.0 V Vql = o.a V 

VjL = 0.8 V FLOAT = ±0.5 V 

V,HC = Vcc -0.6 V 
V,LC = 0.45 V 



APPENDIX E 
Z80 DIRECT MEMORY ADDRESS (DMA) 



Z8410 

Z8<rDllIil Direct 
Momory Access Controllet 




Zilog 



Product 
Specllicatloii 



June 1982 



Fftortur** U Transfers, searches and search/transfers in 

Byte-at-a-Time, Burst or Continuous modes. 
Cycle length and edge timing can be pro- 
grammed to match the speed of any port. 

■ Dual port addresses (source and destination) 
generated for memory-to-I/O, memory- 
to-memory, or I/O-to-I/O operations. 
Addresses may be fixed or automatically 
incremented/decremented. 

■ Next-operation loading without disturbing 
current operations via buffered starting- 



address registers. An entire previous 
sequence can be repeated automatically. 

Extensive programmability of functions. 
CPU can read complete channel status. 

Standard Z-80 Family bus-request and 
prioritized interrupt- request daisy chains 
implemented without external logic. 
Sophisticated, internally modifiable inter- 
rupt vectoring. 

Direct interfacing to system buses without 
external logic. 



1 

e 
M 



G«n«rcd The Z-80 DMA (Direct Memory Access) is a 

DmKription powerful and versatile device for controlling 
and processing transfers of data . Its basic 
function of managing CPU-independent 
transfers between two ports is augmented by 
an array of features that optimize transfer 
speed and control with little or no external 
logic in systems using an 8- or 16-bit data bus 
and a 16-bit address bus. 



Transfers can be done between any two ports 
(source and destination), including memory-to- 
I/O, memory-to-memory, and I/O-to-I/O. Dual 
port addresses are automatically generated for 
each transaction and may be either fixed or 
incrementing/decrementing. In addition, bit- 
maskable byte searches can be performed 
either concurrently with transfers or as an 
operation in itself. 
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Geaaral The Z-80 DMA contains direct interfacing to 

Dascription and independent control of system buses, as 
(Continued) well as sophisticated bus and interrupt con- 
trols. Many programmable features, including 
variable .cycle timing and auto-restart, 
minimize CPU software overhead. They are 
especially useful in adapting this special- 



purpose transfer processor to a broad variety 
of memory, I/O and CPU environments. 

The Z-80 DMA is an n-channel silicon-gate 
depletion- load device packaged in a 40-pin 
plastic or ceramic DIP. It uses a single +5 ^ 
power siipply and the standard Z-80 Family 
single-phase clock. 



Functional Classes of Operation. The Z-80 DMA has 
Description three basic classes of operation: 

■ Transfers of data between two ports (memory 
or I/O peripheral) 

■ Searches for a particular 8-bit maskable 
byte at a single port in memory or an I/O 
peripheral 

■ Combined transfers with simultaneous 
search between two ports 

Figure 4 illustrates the basic functions 
served by these classes of operation. 

During a transfer, the DMA assumes control 
of the system address and data buses. Data is 
read from one addressable port and written to 
the other addressable port, byte by byte. The 
ports may be programmed to be either system 
main memory or peripheral I/O devices. Thus, 
a block of data may be written from one 
peripheral to another, from one area of main 
memory to another, or from a peripheral to 
main memory and vice versa. 




During a search-only operation, data is read 
from the source port and compared byte by 
byte with a DMA-internal register containing a 
programmable match byte. This match byte 
may optionally be masked so that only certair 
bits within the match byte are compared. 
Search rates up to 1.25M bytes per second Ccn 
be obtained with the 2.5 MHz Z-80 DMA or 2y[ 
bytes per second with the 4 MHz Z-80A DMA. 

In combined searches and transfers, data 
is transferred between two ports while 
simultaneously searching for a bit-maskable 
byte match. 

Data transfers or searches can be pro- 
grammed to stop or interrupt under various 
conditions. In addition, CPU-readable status 
bits can be programmed to reflect the 
condition. 

Modes of Operation. The Z-80 DMA can be 
programmed to operate in one of three transfer 
and/or search modes: 

■ Byte-at-a-Time: data operations are per- 
formed one byte at a time. Between each 
byte operation the system buses are releas !d 
to the CPU. The buses are reguested agair 
for each succeeding byte operation. 

■ Burst: data operations continue until a 
port's Ready line to the DMA goes inactive. 
The DMA then stops and releases the system 
buses after completing its current byte 
operation. 

■ Continuous: data operations continue until 
the end of the programmed block of data is 
reached before the system buses are 
released. If a port's Ready line goes inactii/e 
before this occurs, the DMA simply pauses 
until the Ready line comes active again. 




1. S«at«h (iMfflofy 

2. TranilKT m«fflOTy-lo.immoiy (epIlmMI Itilrch) 
a. Tranalsf iiMfnwy.la.VO <optkinBl March) 

4. SMrehl/O 

s. Trantfir l/O-lo-wo (optional aaarch) 



Figur* 3. Typical Z-80 EnTironnuint 



Figur* 4. Benic Functioni oi lh« Z-BO DMA 
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Functtona) In all modes, once a byte of data is read into 

Dascrlptlon the DMA, the operation on the byte will be 
(Continued) completed in an orderly fashion, regardless of 
the state of other signals (including a port's 
Ready line). 

Due to the DMA's high-speed buffered 
method of reading data, operations on one 
byte are not completed until the next byte is 
read In. This means that total transfer or 
search block lengths must be two or more 
bytes, and that block lengths programmed into 
the DMA must be one byte less than the 
desired block length (count is N- 1 where N is 
the block length). 

Commatnds and Stcrtiu. The Z-80 DMA has 
several writable control registers and readable 
status registers available to the CPU. Control 
bytes can be written to the DMA whenever the 
DMA is not controlling the system buses, but 
the act of writing a control byte to the DMA 
disables the DMA until it is again enabled by a 
specific command. Status bytes can also be 
read at any such time, but writing the Read 
Status Byte command or the Initiate Read 
Sequence command disables the DMA. 

Control bytes to the DMA include those 
which effect immediate command actions such 
as enable, disable, reset, load starting-address 
buffers, continue, clear counters, clear status 
bits and the like. In addition, many mode- 
setting control bytes can be written, including 
mode and class of operation, port configura- 
tion, starting addresses, block length, address 
counting rule, match and match-mask byte, 
interrupt conditions, interrupt vector, status- 
affects-vector condition, pulse counting, auto 
restart. Ready-line and Wait-line rules, and 
read mask. 

Readable status registers include a general 
status byte reflecting Ready-line, end-of-block, 
byte-match and interrupt conditions, as well as 
2-byte registers for the current byte count. 
Port A address and Port B address. 

Vcnriobl* Cycl*. The Z-80 DMA has the 
unique feature of programmable operation- 
cycle length. This is valuable in tailoring the 
DMA to the particular requirements of other 
system components (fast or slow) and max- 
imizes the data-transfer rate. It also eliminates 
external logic for signal conditioning. 

There are two aspects to the variable cycle 
feature. First, the entire read and write cycles 
(periods) associated with the source and 
destination ports can be independently pro- 
grammed as 2, 3 or 4 T-cycles long (more if 
Wait cycles are used), thereby increasing or 



decreasing the speed with which all DMA 
signals change (Figure 5). 

Second, the four signals in each port 
specifically associated with transfers of data 
(I/O Request, Memory Request, Read, and 
Write) can each have its active trailing edge 
terminated one-half T-cycle early. This adds a 
further dimension of flexibility and speed, 
allowing such things as shorter-than-normal 
Read or Write signals that go inactive before 
data starts to change. 

Address Generation. Two 16-bit addresses are 
generated by the Z-80 DMA for every transfer 
operation, one address for the source port and 
another for the destination port. Each address 
can be either variable or fixed. Variable 
addresses can increment or decrement from 
the programmed starting address. The fixed- 
address capability eliminates the need for 
separate enabling wires to I/O ports. 

Port addresses are multiplexed onto the 
system address bus, depending on whether the 
DMA is reading the source port or writing to 
the destination port. Two readable address 
counters (2 bytes each) keep the current 
address of each port. 

Auto Restart. The starting addresses of either 
port can be reloaded automatically at the end 
of a block. This option is selected by the Auto 
Restart control bit. The byte counter is cleared 
when the addresses are reloaded. 

The Auto Restart feature relieves the CPU of 
software overhead for repetitive operations 
such as CRT refresh and many others. More- 
over, when the CPU has access to the buses 
during byte-at-a-time or burst transfers, dif- 
ferent starting addresses can be written into 
buffer registers during transfers, causing the 
Auto Restart to begin at a new location. 

Interrupts. The Z-80 DMA can be programmed 
to interrupt the CPU on three conditions: 

■ Interrupt on Ready (before requesting bus) 

■ Interrupt on Match 

■ Interrupt on End of Block 
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Functional Any of these interrupts cause an interrupt- 

Description pending status bit to be set, and each of them 
(Continued) can optionally alter the DMA's interrujrt vec- 
tor. Due to the buffered constraint mentioned 
under "Modes of Operation," interrupts on 
Match at End of Block are caused by matches 
to the byte just prior to the last byte in the 
block. 

The DMA shares the Z-80 Family's elaborate 
interrupt scheme, which provides fast inter- 
rupt service in real-time applications. In a 
Z-80 CPU environment, the DMA passes its 
internally modifiable 8- bit interrupt vector to 
the CPU, which adds an additional eight bits 
to form the memory address of the interrupt- 
routine table. This table contains the address 
of the beginning of the interrupt routine itself. 



In this process, CPU control is transferred 
directly to the interrupt routine, so that the 
next instruction executed after an interrupt 
acknowledge is the first instruction of the inter- 
rupt routine itself. 

Pulse Generation. External devices can keep 
track of how many bytes have been transferred 
by using the DMA's pulse output, which pro- 
vides a signal at 256-byte intervals. The inter- 
val sequence may be offset at the beginning by 
1 to 255 bytes. 

The Interrupt line outputs the pulse signal in 
a manner that prevents misinterpretation by 
the CPU as an interrupt request, since it only 
appears when the Bus Request and Bus 
Acknowledge lines are both active. 



Pin Afl-Ais. System >4a'a'ress Bus (output, 3-state). 

Description Addresses generated by the DMA are sent to 
both source and destination ports (main 
memory or I/O peripherals) on these lines. 

BAI. Bus Acknowledge In (input, active Low). 
Signals that the system buses have been 
released for DMA contr ol. In multiple-DMA 
configurations, the BAI pin of the highest 
priority DMA is normally connected to the Bus 
Acknowledge pin of t he CPU. Lower-pr iority 
DMAs have their BAI connected to the BAO of 
a higher-priority DMA. 

BAO. Bus Acknowledge Out (output, active 
Low). In a multiple-DMA configuration, this 
pin signals that no other higher- prior ity DMA 
has requested the system buses. BAI and BAO 
form a daisy chain for multiple-DMA priority 
resolution over bus control. 



BUSREQ. Bus Bequest (bidirectional, active 
Low, open drain). As an output, it sends 
requests for control of the system address bus, 
data bus and control bus to the CPU. As an 

input, when multiple DMAs are strung 

toget her in a priority daisy chain via BAI and 
BAO, it senses when another DMA has 
requested the buses and causes this DMA to 
refrain from bus requesting until the other 
DMA is finished. Because it is a bidirectional 
pin, there cannot be any buffers between this 
DMA and any other DMA. It can, however, 
have a buffer between it and the CPU because 
it is unidirectional into the CPU. A pull-up 
resistor is connected to this pin. 



CE/WAIT. Chip Enable and Wait (input, 
active Low). Normally this functions only as a 
CE line , but it can also be programmed to 
serve a WAIT function. As a CE l ine fr om the 
CPU, it becomes active when WR and lORQ 
are active and the I/O port address on the 



system address bus is the DMA's address, 
thereby allowing a transfer of control or com- 
mand bytes from the CPU to the DMA. As a 
WAIT line from memory or I/O devices, after 
the DMA has received a bus-request ack- 
nowledge from the CPU, it causes wait states 
to be inserted in the DMA's operation cycles 
thereby slowing the DMA to a speed that 
matches the memory or I/O device. 

CLK. System Clock (input). Standard Z-80 
single-phase clock at 2.5 MHz (Z-80 DMA) or 
4.0 MHz (Z-80A DMA). For slower system 
clocks, a TTL gate with a pullup resistor may 
be adequate to meet the timing and voltage 
level specification. For higher-speed systems, 
use a clock driver with an active pullup to 
meet the Vjh specification and risetime 
requirements. In all cases there should be a 
resistive pullup to the power supply of lOK 
ohms (max) to ensure proper power when the 
DMA is reset. 

Dq-Dt- System Data Bus (bidirectional, 
3-state). Commands from the CPU, DMA 
status, and data from memory or I/O 
peripherals are transferred on these lines. 

IH. Interrupt Enable In {input, active High). 
This is used with lEO to form a priority daisy 
chain when there is more than one interrupt- 
driven device. A High on this line indicates 
that no other device of higher priority is being 
serviced by a CPU interrupt service routine. 

lEO. Interrupt Enable Out (output, active 
High). lEO is High only if lEI is High and the 
CPU is not servicing an interrupt from this 
DMA. Thus, this signal blocks lower-priority 
devices from interrupting while a higher- 
priority device is being serviced by its CPU 
interrupt service routine. 



Pin INT/PULSE, /nterrup/ flegues/ (oulpijt, ac>r/e 

Description Low, open drain). This requests a CPU inter 
(Continued) rupt. The CPU a cknowledges the internjgt by 
pulling its lORQ output Low during a n M l 
cycle. It is typically connected to the INT pin 
of the C PU w ith a puUup resistor and tied to 
all other INT pins in the system. This pin can 
also be used to generate periodic pulses to an 
external device. It can be used this way only 
when the DMA is bus ma ster (i.e., the CPU's 
BUSREQ and BUSACK lines are both Low 
and the CPU cannot see interrupts). 

lORQ. Input/Output Bequest (bidirectional, 
active Low, 3-state). As an input, this indicates 
that the lower half of the address bus holds a 
valid I/O port address for transfer of control or 
status bytes from or to the CPU, respectively; 
this D MA is the addressed port if its CE pin 
and its WR or RD pins are simultaneously 
active. As an output, after the DMA has taken 
controlof the system buses, it indicates that 
the 8-bit or 16-bit address bus holds a valid 
port address for another I/O d evice i nvolved in 
a DMA transfer of data. When lORQ and Ml 
are both active simultaneously, an interrupt 
acknowledge is indicated. 

ML Machine Cycle One (input, active Low). 
Indicates that the current CPU machine cycle 
is an instruction fetch. It is used by the DMA 
to decode the return-from- interrupt instruction 
(RETI) (ED-4D) sent by the_CPU. During two^ 
byte instruction fetches. Ml is active as each 



Internal The internal structure of the Z-80 DMA 

Structure includes driver and receiver circuitry for inter- 

facing with an 8-bit system data bus, a 16-bit 
system address bus, and system control lines 
(Figure 6). In a Z-80 CPU environment, the 
DMA can be tied directly to the analogous pins 
on the CPU (Figure 7 ) with no additional buf- 
fering, except for the CE/WAIT line. 

The DMA's internal data bus interfaces with 
the system data bus and services all internal 
logic and registers. Addresses generated from 
this logic for Ports A and B (source and des- 
tination) of the DMA's single transfer channel 
are multiplexed onto the system address bus. 



opcode byte is fetched. An interrupt ack- 
nowledge IS indicated when both MTand 
rORQ are active. 

MREQ. Memory Request (output, active Low, 
3-state). This indicates that the address bus 
holds a valid address for a memory read or 
write operation. After the DMA has taken con- 
trol of the system buses, it indicates a DMA 
transfer request from or to memory. 

RD. /?eoc? (bidirectional, active Low, 3-state). 
As an input, this indicates that the CPU wantp 
to read status bytes from the DMA's read 
registers. As an output, after the DMA has 
taken control of the system buses, it indicates a 
DMA-controlled read from a memory or I/O 
port address. 

RDY. Ready (input, programmable active Low 
or High). This is monitored by the DMA to 
determine when a peripheral device associated 
with a DMA port is ready for a read or write 
operation. Depending on the mode of DMA 
operation (Byte, Burst or Continuous), the RDY 
line ind irectly co ntrols DMA activity by caus- 
ing the BUSREQ line to go Low or High. 

WR. Write fbidirectional, active Low, 3-state). 
As an input, this indicates that the CPU wants 
to write control or command bytes to the DMA 
write registers. As an output, after the DMA 
has taken control of the system buses, it 
indicates a DMA-controlled write to a memory 
or I/O port address. 



Specialized logic circuits in the DMA are 
dedicated to the various functions of external 
bus interfacing, internal bus control, byte 
matching, byte counting, periodic pulse 
generation, CPU interrupts, bus requests and 
address generation. A set of twenty-one 
writable control registers and seven readable 
siatus registers provides the means by which 
the CPU governs and monitors the activities of 
these logic circuits. All registers are eight bits 
wide, with double-byte information stored in 
adjacent registers. The two address- counters 
(two bytes each) for Ports A and B are buffered 
by the two starting addresses. 
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Figura E. Block Cttagram 



Internal The 21 writable control registers are 

Structure organized into seven base-register groups, 

(Continued) most of which have multiple registers. The 

base registers in each writable group contain 
both control/command bits and pointer bits 
that can be set to address other registers within 
the group. The seven readable status registers 
have no analogous second-level registers. 
The registers are designated as follows, 
according to their base-register groups: 

WR0-WR6 — Write Register groups 
through 6 (7 base registers plus 14 associ- 
ated registers) 
RR0-RR6 — Read Registers through 6 

Writing to a register within a write-register 
group involves first writing to the base 
register, with the appropriate pointer bits set, 
then writing to one or more of the other 
registers within the group. All seven of the 
readable status registers are accessed sequen- 
tially according to a programmable mask con- 
tained in one of the writable registers. The sec- 
tion entitled "Programming" explains this in 
more detail. 

A pipelining scheme is used for reading data 
in. The programmed block length is the 
number of bytes compared to the byte counter, 
which increments at the end of each cycle. In 
searches, data byte comparisons with the 
match byte are made during the read cycle of 
the next byte. Matches are, therefore, dis- 
covered only after the next byte is read in. 

In multiple-DMA configurations, interrupt- 
request daisy chains are prioritized by the 
order in which their lEI and lEO lines are con- 
nected (Zilog Application Note 03-0041-01, The 
Z-80 Family Program Interrupt Structure). The 



system bus, however, may not be pre-empted. 
Any DMA that gains access to the system bus 
keeps the bus until it is finished. 

Write Registers 

WRO Base register byte 

Port A starting address (low byte) 
Port A starting address (high byte) 
Block length (low byte) 
Block length (high byte) 

WRl Base register byte 

Port A variable-timing byte 

WR2 Base register byte 

Port B variable-timing byte 

WR3 Base register byte 
Mask byte 
Match byte 

WR4 Base register byte 

Port B starting address (low byte) 
Port B starting address (high byte) 
Interrupt control byte 
Pulse control byte 
Interrupt vector 

WR5 Base register byte 

WR6 Base register byte 
Read mask 

Read Registers 

RRO Status byte 

RR 1 Byte counter (low byte) 

RR2 Byte counter (high byte) 

RR3 Port A address counter (low byte) 

RR4 Port A address counter (high byte) 

RR5 Port B address counter (low byte) 

RR6 Port'B address counter (high byte) 




TO. NEXT DMA 



Figtur* 7. Multiple-DMA IntarconnacUon to Ih* Z-80 CPU 



Programming The Z-80 DMA has two programmable fun- 
damental states: (1) an enabled state, in which 
it can gain control of the system buses and 
direct the transfer of data between ports, and 
(2) a disabled state, in which it can initiate 
neither bus requests nor data transfers. When 
the DMA is powered up or reset by any means, 
it is automatically placed into the disabled 
state. Program commands can be written to it 
by the CPU in either state, but this auto- 
matically puts the DMA in the disabled state, 
which is maintained until an enable command 
is issued by the CPU. The CPU must program 
the DMA in advance of any data search or 
transfer by addressing it as an t/O port and 
sending a sequence of control bytes using an 
Output instruction (such as OTIR for the 
Z-80 CPU). 

Writing. Control or command bytes are writ- 
ten into one or more of the Write Register 
groups (WR0-WR6) by first writing to the base 
register byte in that group. All groups have 
base registers and most groups have additional 
associated registers. The associated registers 
in a group are sequentially accessed by first 
writing a byte to the base register containing 
register-group identification and pointer bits 
(I's) to one or more of that base register's 
associated registers. 

This is illustrated in Figure 8b. In this 
figure, the sequence in which associated 
registers within a group can be written to is 
shown by the vertical position of the associated 
registers. For example, if a byte written to the 
DMA contains the bits that identify WRO (bits 
DO, Dl and D7), and also contains I's in the 
bit positions that point to the associated "Port 
A Starting Address (low byte)" and "Port A 
Starting Address (high byte)," then the next 
two bytes written to the DMA will be stored in 
these two registers, in that order. 

Reading. The Read Registers (RR0-RR6) are 
read by the CPU by addressing the DMA as an 
I/O port using an Input instruction (such as 
INIR for the Z-80 CPU). The readable bytes 
contain DMA status, byte-counter values, and 
port addresses since the last DMA reset. The 



registers are always read in a fixed sequence 
beginning with RRO and ending with RR6. 
However, the register read in this sequence is 
determined by programming the Read Mask in 
WR6. The sequence of reading is initialized by 
writing an Initiate Read Sequence or Set Read 
Status command to WR6. After a Reset DMA, 
the sequence must be initialized with the 
Initiate Read Sequence command or a Read 
Status command. The sequence of reading all 
registers that are not excluded by the Read 
Mask register must be completed before a new 
Initiate Read Sequence or Read Status 
command. 

Fixed-Address Programming. A special cir- 
cumstance arises when programming a desti- 
nation port to have a fixed address. The load 
command in WR6 only loads a fixed address to 
a port selected as the source, not to a port 
selected as the destination. Therefore, a fixed 
destination address must be loaded by tem- 
porarily declaring it a fixed-source address 
and subsequently declaring the true source as 
such, thereby implicitly making the other a 
destination. 

The following example illustrates the steps in 
this procedure, assuming that transfers are to 
occur from a variable-address source (Port A) 
to a fixed- address destination (Port B): 

1 . Temporarily declare Port B as source in 
WRO. 

2. Load Port B address in WR6. 

3. Declare Port A as source in WRO. 

4. Load Port A address in WR6. 

5. Enable DMA in WR6. 

Figure 9 illustrates a program to transfer 
data from memory (Port A) to a peripheral 
device (Port B). In this example, the Port A 
memory starting address is 1050h and the Port 
B peripheral fixed address is 05h. Note that 
the data flow is IOOIh bytes — one more than 
specified by the block length. The table of 
DMA commands may be stored in consecutive 
memory locations and transferred to the DMA 
with an output instruction such as the Z-80 
CPU's OTIR instruction. 
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Inactive In its disabled or inactive state, the DMA is 

State Timing addressed by the CPU as an I/O peripheral for 
(DMA as CPU write and read (control and status) operations. 
Peripheral) Write timing is illustrated in Figure 10. 
Reading of the DMA's status byte, byte 
counter or port address counters is illustrated 



in Figure 1 1 . These operation s requ ire less 
than three T-cycles. The CE, lORQ and 
RD lines are made active over two rising edges 
of CLK, and data appears on the bus approx- 
imately one T-cycle after they become active. 



lORQ 
WR 



€> 






Figure 10. CPU-to-DMA Write Cycle 



Figure U. CPU-to-DMA Head Cycle 



Active State Deiault Read' and Write Cycles. By default. 
Timing and after reset, the DMA's timing of read and 

(DMA as Bus write operations is exactly the same as the Z-80" 
Controller) CPU's timing of read and write cycles ioi 

memory and I/O peripherals, with one excep- 
tion: during a read cycle, data is latched on 
the falling edge o£ T3 and held on the data bus 
across the boundary between read and write 
cycles, through the end of the following write 
cycle. 

Figure 12 illustrates the timing for memory- 
to-I/O port transfers and Figure 13 illustrates 
I/O-to-memory transfers. Memory-to-memory 
and I/O-to-I/O transfer timings are simply per- 
mutations of these diagrams. 

The default timing uses three T-cycles for 
memory transactions and four T-cycles for I/O 
trailsactions, which include one automatically 



inserted wait cycle between T2 and T3. If the 
CE/W AIT line is programmed to act as a 
WAIT line during the DMA's active state, it is 
sampled on the falling edge of Tj for memory 
transactions an d the fallin g edge of Ty/ for I/O 
transactions. If CE/WAIT is Low during this 
tim e another T-cycle is added, during which 
the CE/WAIT line will again be sampled. The 
duration of transactions can thus be indef- 
initely extended. 

Variable Cycle and Edge Timing. The Z-80 
DMA's default operation-cycle length for the 
source (read) port and destination (write) port 
can be independently programmed. This 
variable-cycle feature allows read or write 
cycles consisting of two, three or four T-cycles 
(more if Wait cycles are inserted), thereby 
increasing or decreasing the speed of all 
signals generated by the DMA. In addition. 
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the trailing edges of the K5H0, MREQ, RD and 
WR signals can be independently terminated 
one-half cycle early. Figure 14 illustrates this. 

In the varia ble- cycle mode, unlike default 
timing, lORQ comes a ctive one-half cy cle 
before MRlQ, RD and WR. CE/WAIT can be 
used to extend only the 3 or 4 T-cycle variable 
memory cycles and only the 4-cycle variable 
I/O cycle. The CE/WAIT line is sampled at the 
falling edge of Tj for 3- or 4-cycle memory 
cycles, and at the falling edge of T3 for 4-cycle 
I/O cycles. 

During transfers, data is latched on the 
clock edge causing the rising edge of RD and 
held through the end of the write cycle. 



Bua R*qu««t«. Figure 15 illustrates the bus 
request and acceptance timing. The RDY line, 
which may be programmed active High or 
Low, is sampled on every rising edge of CLK. 
If it is found to be active, and if the bus is not 
in use by any other device, th e following rising 
edg e of CLK drives BUSREQ low. After receiv- 
ing BUSREQ the CPU acknowledges on the 
BAI input either directly or through a 
multiple- D MA d aisy chain. When a Low is 
detected on BAI for two consecutive rising 
edges of CLK, the DMA will begin transferring 
data on the next rising edge of CLK. 
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Active State Bus Releas o Byt»-at- a-Tlm«. In Byle-at-a- 
Timing Time mode, BUSREQ is brouajit Ht^ on the 

(DMA as Bus rising edge of CLK prior to fife MHMksach 
Controller) read cycle (search-only) or write cycle 
(Continued) (transfer and transfer/search) as illustrated in 
Figure 16. This is done regardless of the state 
of RDY. There is no possibility of confusion 
when a Z-80 CPU is used since the CPU 
cannot begin an operation until the 'following 
T-cycle. Most other CPUs are not bothered by 
this either, although note should be taken of it. 
The next bus re guest for the next b yte will 
come after both BUSREQ and BAI have 
returned High. 

Bus Release at End of Block. In Burst and 
Continuo us modes, an end of block causes 
BUSREQ to go High usually on the same rising 
edge of CLK in which the DMA completes the 
transfer of the data block (Figure 17). The last 
byte in the block is transferred even if RDY 
goes inactive before completion of the last byte 
transfer. 

Bus Release on Not Ready. In B urst mode , 
when RDY goes inactive it causes BUSREQ to 
go High on the next rising edge of CLK after 
the completion of its curre nt byte op eration 
(Figure 18). The action on BUSREQ is thus 
somewhat delayed from action on the RDY 
line. The DMA always completes its current 
byte operation in an orderly fashion before 
releasing the bus. 

By contrast, BUSREQ is not released in 
Continuous mode when RDY goes inactive. 



Instead, the DMA idles after completing the 
current byte operation, awaiting an active RDY 
again. 

Bus Release on Match. If the DMA is pro- 
grammed to stop on match in B urst or C on- 
tinuous modes, a match causes BUSREQ to go 
inactive on the next DMA operation, i.e., at 
the end of the next read in a search or at the 
end of the following write in a transfer (Figure 
19). Due to the pipelining scheme, matches 
are determined while the next DMA read or 
write is being performed. 

The RDY line can go inactive after the 
matching operation begins without affecting 
this bus-release timing. 

Interrupts. Timings for interrupt acknowledge 
and return from interrupt are the same as tim- 
ings for these in other Z-80 peripherals. Refer 
to Zilog Application Note 03-0041-01 (The Z-80 
Family Program Interrupt Structure). 

Interrupt on RDY (interrupt befor e reguest - 
ing bus) does not directly affect the BUSREQ 
line. Instead, the interrupt service routine 
must handle this by issuing the following 
commands to WR6: 

1 . Enable after Return From Interrupt (RETI) 
Command — Hex B7 

2. Enable DMA — Hex 87 

3. An RETI instruction that resets the 
Interrupt Under Service latch in the 
Z-80 DMA. 
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APPENDIX F 
FLOPPY DISK CONTROLLER (FDC) 



WESTER 1^1 DiG/TAL 

CORPORAT/ON 

WD279X.02 Floppy Disk Formatter/Controller Family 



FEATURES 

•= ON-CHIP PLL DATA SEPARATOR 

« ON-CHIP WRITE PRECOMPENSATION LOGIC 

• SINGLE +5V SUPPLY 

» ACCOMMODATES SINGLE AND DOUBLE DENSITY 
FORMATS 

IBM 3740 (FM) 
IBM 34 (MFM) 

• AUTOMATIC SEEK WITH VERIFY 
« MULTIPLE SECTOR READ/WRITE 

• TTL COMPATIBLE 

• PROGRAMMABLE CONTROL 

SELECTABLE TRACK-TO-TRACK ACCESS 
HEAD LOAD TIMING 

« SOFTWARE COMPATIBLE WITH THE FD179X SERIES 

« SOFT SECTOR FORMAT COMPATIBILITY 

APPLICATIONS 

8" FLOPPY AND 5V4" MINI FLOPPY CONTROLLER 
SINGLE OR DOUBLE DENSITY 
CONTROLLER/FORMATTER 



The WD279X Family are MOS/LSI devices which perform 
the functions of a Floppy Disk Controller/Formatter. Soft- 
ware compatible with its predecessor, the FD179X, the 
device also contains a high performance Phase-Lock-Loop 
Data Separator as well as Write Precompensation Logic. 

When operating in Double Density mode, Write Precom- 
pensation is automatically engaged to a value programmed 
via an external potentiometer. An on-chip VCO and phase 
comparator allows adjustable frequency range for 5V4 " or 
8" Floppy Disk interfacing. 

The WD279X is fabricated in NMOS silicon gate technology 
and available in a 40 pin dual-in-line ceramic or plastic 
package. 
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Figure 1. 



PIN OUTS 
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PIN 
NUMBER 


PIN NAME 


SYMBOL 


FUNCTION 


1 
19 


ENABLE PRECOMP 


ENP 

MFf 


A Logic high on this input enables write precompen- 
sation to be perfornned on the Write Data output. 

A logic low (50 microseconds min.) on this input 
resets the device and loads HEX 03 into the com- 
mand register. The Not Ready (Status Bit 7) is reset 
during MR ACTIVE. When MR is brought to a logic 
high a RESTORE Command is executed, regardless 
of the state of the Ready signal from the drive. Also, 
HEX 01 is loaded into sector register. 


MASTER RESET 


20 


POWER SUPPLIES 


vss 


Ground 


21 




vcc 


+ 5\/ ±5% 


COMPUTER IN 

2 

3 
4 


FERFACE: 


WE 

cs 

RE 


A logic low on this input gates data on the DAL into 
the selected register when CS is low. 

A logic low on this input selects the chip and enables 
computer communication with the device. 

A logic low on this input controls the placement^ of 
data from a selected register on the DAL when CS is 
low 


WRITE ENABLE 


CHIP SELECT 


READ ENABLE 


5,6 


REGISTER SFI FCT LINES 


A0,A1 


These inputs select the register to receive/transfer 
data on the DAL lines under RE and WE control: 

CS A1 AO RE WE 

status Reg Command Reg 
1 Track Reg Track Reg 
1 Sector Reg Sector Reg 
1 1 Data Reg Data Reg 


7-14 


DATA ACCESS LINES 


DAL0-DAL7 


Eight bit bi-directional bus used for transfer of com- 
mands, status, and data. These lines are inverted 
(active low) on WD2791 and WD2795. 


24 


CLOCK 


CLK 


This input requires a free-running 50% duty cycle 
square wave clock for internal timing reference, 2 
MHz + 1% for 8" drives, 1 MHz ± 1% for mini- 
floppies. 


38 


DATA REQUEST 


DRQ 


This output indicates that the Data Register contains 
assembled data in Read operations, or the DR is 
empty in Write operations. This signal is reset when 
serviced by the computer through reading or loading 
the DR. 


39 


INTERRUPT REQUEST 


INTRQ 


This output is set at the completion of any command 
and is reset when the Status register is read or the 
Command register is written to. 


FLOPPY DISK 


NTERFACE: 






15 


STEP 


STEP 


The step output contains a pulse for each step. 


16 


DIRECTION 


DIRC 


Direction Output is active high when stepping in, 
active low when stepping out. 


17 


51/4 ,"8" SELECT 


5/8 


This input selects the internal VCO frequency for use 
with 5V4 " drives or 8" drives. 


18 


READ PULSE WIDTH 


RPW 


An external potentiometer tied to this input controls 
the phase comparator within the data separator. 



PIN 
NUMBER 


PIN NAME 


SYMBOL 


FUNCTION 


22 


TEST 


TEST 


A logic low on this Input allows adjustment of exter- 
nal resistors by enabling internal signals to appear on 
selected pins. 


23 
25 


PUMP 

ENABLE MINI-FLOPPY 
(2791,2793) 


PUMP 


High-Impedance output signal which is forced high 
or low to increase/decrease the VCO frequency. 

A logic low on this input_enables an internal -;- 2 of 
the Master Clock when 5/8 Is also at a logic 0. This 
allows both S'A " and 8" drive operation with a single 
2 MHz clock. For a 1 MHz clock on Pin 24, this line 
must be left open or tied to a Logic 1. 


ENMF 


25 


SIDE SELECT OUTPUT 
(2795, 2797) 


SSO 


The logic level of the Side Select Output is directly 
controlled by the 'S' flag in Type II or III commands. 
When U = 1, SSO is set to a logic 1. When U = 0, 
SSO is set to a logic 0. The SSO is compared with the 
side information in the Sector I.D. Field. If they do not 
compare Status Bit 4 (RNF) is set. The Side Select 
Output is only updated at the beginning of a Type II or 
III command. It is forced to a logic upon a MASTER 
RESET condition. 


26 
27 


VOLTAGE-CONTROLLED 
OSCILUTOR 


VCO 


An external capacitor tied to this pin adjusts the VCO 
center frequency. 

Ttie data input signal directly from the drive. This 
input shall be a negative pulse for each recorded flux 
transition. 


RAW READ 


RAW READ 


28 


HEAD LOAD 


HLD 


The HLD output controls the loading of the Read- 
Write head against the media 


29 


TRACK GREATER 
THAN 43 


TG43 


This output informs the drive that the Read/Write 
head is positioned between tracks 44-76. This output 
Is valid only during Read and Write Commands. 


30 


WRITE GATE 


WG 


This output is made valid before writing is to be 
performed on the diskette. 


31 


WRITE DATA 


WD 


A 250ns (MFM) or 500 ns (FM) output pulse per flux 
transition. WD contains the unique Address marks as 
well as data and clock in both FM and MFM formats. 


32 


READY 


READY 


This input indicates disk readiness and is sampled 
for a logic high before Read or Write commands are 
performed. If Ready is low the Read or Write 
operation is not performed and an Intenxipt is 
generated. Type 1 operations are perfomied regard- 
less of the state of Ready. The Ready input appears in 
inverted format as Status Register bit 7. 


33 
34 
35 


WRITE PRECOMP 
WIDTH 


WPW 
TROO 
IP 


An external potentiometer tied to this input controls 
the amount of delay in Write precompensation mode'. 

This input informs the WD279X that the Read/Write 
head is positioned over Track 00. 

This input informs the WD279X when the index hole 
is encountered on the diskette. 


TRACK 00 


INDEX PULSE 
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PIN NUMBER 


PIN NAME 


SYMBOL 


FUNCTION 


36 
37 

40 


WRITE PROTECT 


WPRT 


This input is sampled whenever a Write Command is 
received. A logic low terminates the command and 
sets the Write Protect Status bit. 

This input pin selects either single or double density 
operation. When DDEN = 0, double density is 
selected. When DDEN = 1, single density is 
selected. 

When a logic high is found on the HLT input the head 
is assumed to be engaged. It is typically derived from 
a 1 shot triggered by HLD. 


DOUBLE DENSITY 
HEAD LOAD TIMING 


DDEN 
HLT 



GENERAL DESCRIPTION 

The WD279X are N-Channel Silicon Gate MOS LSI devices 
which perform the functions of a Floppy Disk For- 
matter/Controller in a single chip implementation. The 
WD279X, which can be considered the end result of both 
the FD1771 and FD179X designs, is IBM 3740 compatible in 
single density mode (FM) and System 34 compatible in 
Double Density Mode (MFM). The WD279X contains all the 
features of its predecessor the FD179X plus a high per- 
formance Phase-Lock-Loop Data Separator as well as Write 
Precompensation Logic. In Double Density mode, Write 
Precompensation is automatically engaged to a value 
programmed via an external potentiometer. In order to 
maintain compatibility, the FD1771, FD179X and WD279X 
designs were made as close as possible with the computer 
interface, instmction set, and I/O registers being identical. 
Also, head load control is identical. In each case, the actual 
pin assignments vary by only a few pins from any one to 
another. 

The processor interface consists of an 8-bit bi-directional 
bus for data, status, and control word transfers. The 
WD279X is set up to operate on a multiplexed bus with 
other bus-oriented devices. 

The WD279X is TTL compatible on all inputs and outputs. 
The outputs will drive one TTL load or three LS loads. The 
2793 is identical to the 2791 except the DAL lines are TRUE 
for systems that utilize true data busses. 
The 2795/7 has a side select output for controlling double 
sided drives. 

ORGANIZATION 

The Floppy Disk Formatter block diagram is illustrated on 
page 5. The primary sections include the parallel processor 
interface and the Floppy Disk interface. 

Data Shift Register ~ This 8-bit register ass embles serial 
data from the Read Data input (RAW READ) during Read 
operations and transfers serial data to the Write Data 
output during Write operations. 

Data Register — This 8-bit register is used as a holding 
register during Disk Read and Write operations in Disk 
Read operations the assembled data byte is transfen'ed in 
parallel to the Data Register from the Data Shift Register. In 
Disk Write operations information is transferred In parallel 
from the Data Register to the Data Shift Register. 

When executing the Seek command the Data Register 
holds the address of the desired Track position. This 



register is loaded from the DAL and gated onto the DAL 
under processor control. 

Track Register — This 8-bit register holds the track number 
of the current Read/Write head position. It is incremented 
by one every time the head is stepped in (towards track 76) 
and decremented by one when the head is stepped out 
(towards track 00). The contents of the register are com- 
pared with the recorded track numtier In the ID field during 
disk Read, Write and Verify operations. The Track Register 
can be loaded from or transferred to the DAL. This Register 
should not be loaded when the device is busy. 
Sector Register (SR) — ■ This 8-blt register holds the address 
of the desired sector position. The contents of the register 
are compared with the recorded sector number in the ID 
field during disk Read or Write operations. The Sector 
Register contents can be loaded from or transferred to the 
DAL. This register should not be loaded when the device is 
busy. 

Command Register (CR) — This 8-bit register holds the 
command presently t>eing executed. This register should 
not be loaded when the device is busy unless the new 
command is a force interrupt. The command register can 
be loaded from the DAL, but not read onto the DAL 
Status Register (SIR) — This 8-bit register holds device 
Status information. The meaning of the Status bits is a 
function of the type of command previously executed. This 
register can be read onto the DAL, but not loaded from the 
DAL 

CRC Logic — This logic is used to check or to generate the 
16-bit Cyclic Redundancy Check (CRQ. The polynomial is: 
G(x) = x16 + x12 + x5 -I- 1. 

The CRC includes all infomiation starting with the address 
matk and up to the CRC characters. The CRC register is 
preset to ones prior to data l>eing shifted through the 
circuit 

Arfttimetic/Logic Unit (ALU) — The ALU is a serial compara 
tor, inctementer, and decrementer and is used for register 
modification and comparisons with the disk recorded ID 
field. 

Timing and Control — All computer and Floppy Disk in- 
terface controls are generated through this kigic. The in- 
ternal device timing is generated from an external crystal 
clock. 

AM Detector ~ The address mark detector detects ID, data 
and index address mari<s during read and write operations. 
Write Precompensation — enables write precompensation 
to tie perfomned on the Write Data output. 
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WD279X BLOCK DIAGRAM 



Data Separator — a high performance Phase-Lock-Loop 
Data Separator with on-chip VCO and phase comparator 
allows adjustable frequency range for 5V4 " or 8" Floppy 
Disk interfacing. 

PROCESSOR INTERFACE 

The interface to the processor is accomplished through the 
eight Data Access Lines (DAL) and associated control 
signals. The DAL are used to transfer Data, Status, and 
Control words out of, or into the WD279X. The DAL are 
three state buffers that are enabled as output drivers when 
Chip Select (CS) and Read Enable (RE)_are active (low logic 
state) or act as input receivers when CS and Write Enable 
(WE) are active. 

When transfer of data with the Floppy Disk Controller is 
required by the host processor, the device address is 
decoded and CS Is made low. The address bits A1 and AO, 
combined with the signals RE during a Read operation or 
WE during a Write operation are fhterpreted as selecting- 
the following registers: 



A1 - AO 



READ (RE) 



WRITE (WE) 



Status Register 

1 Track Register 

1 Sector Register 
1 1 Data Register 



Command Register 
Track Register 
Sector Register 
Data Register 



During Direct Memory Access (DMA) types of data trans- 
fers between the Data Register of the WD279X and the 
processor, the Data Request (DRQ) output is used in Data 
Transfer control. This signal also appears as status bit 1 
during Read and Write operations. 

On Disk Read operations the Data Request is activated (set 
high) when an assembled serial input byte is transferred in 
parallel to the Data Register This bit is cleared when the 
Data Register is read by the processor. If the Data Register 
is read after one or more characters are lost, by having new 
data transferred into the register prior to processor readout, 
the Lost Data bit is set in the Status Register. The Read 
operation continues until the end of sector is reached. 

On Disk Write operations the data Request is activated 
when the Data Register transfers its contents to the Data 
Shift Register, and requires a new data byte. It is reset when 
the Data Register is loaded with new data by the processor. 
If new data is not loaded at the time the next serial byte is 
required by the Floppy Disk, a byte of zeroes is written on 
the diskette and the Lost Data bit Is set in the Status 
Register. 

At the completion of every command an INTRQ is 
generated. INTRQ is reset by either reading the status 
register or by loading the command register with a new 
command. In addition, INTRQ is generated if a Force In- 
terrupt command condition is met. 
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The 279 X has two modes of operation according to the 
state of DDEN (Pin 37). When DDEN = 1, Singie Density 
(FM) is selected. When DDEN = 0, Double Density (MFM) 
is selected. In either case, the CLK input (Pin 24) is set at 2 
MHzforS" drives orl MHzfor5i/i" drives. 



On the 2791/2793, the ENMF input (Pin 25) can be used for 
controlling both 5Vi" and 8" drives with a single 2 MHz 
clock. When ENM F = , an internal + 2 of the CLK is 
performed. When ENMF = 1, no divide takes place. This 
allows the use of a 2 MHz clock for both bVn" and 8" 
configurations. 

The intema[VCO frequency must also be set to the proper 
value. The 5/8 input (Pin 17) is used to select data separator 
operation by internally dividing the Read Clock. When 5/8 
= 0, 51A" data separation is selected; when 5/8 = 1, 8" 
drive data separation is selected. 



CLOCK (24) 


ENMF (25) 


5/8(17) 


DRIVE 


2 MHz 
2 MHz 
1 MHz 


1 

1 


1 




8" 

5V4 " 



Note: All other conditions invalid. 

FUNCTIONAL DESCRIPTION 

The WD279X-02 is software compatible with the FD179X-02 
series of Floppy Disk Controllers. Commands, status, and 
data transfers are performed in the same way. Software 
generated for the 179X can be transferred to a 279X system 
without modification. 

In addition to the 179X, the 279X contains an internal Data 
Separator and Write precompensation circuit. The TEST 
(Pin 22) line is used to adjus t both data separator and pre- 
compensation. When TEST = 0, the WD (Pin 31) line is 
internally connected to the output of the write precomp 
one-shot Adjustment of the WPW (Pin 33) line can then be 
accomplished. A second one-shot tracks the precomp set- 
ting at approximately 3:1 to insure adequate Write Data 
pulse widths to meet drive specifications. 

Similarly, Data separation is also adjusted with TEST = 0. 
The TG43 (Pin 29) line is internally connected to the output 
of the read data one-shot, which is adjusted via the RPW 
(Pin 18) line. The DIRC (Pin 16) line contains the Read Clock 
output (.5 MHz for 8" drives). The VCO Trimming capacitor 
(Pin 26) is adjusted for center frequency. 

Internal timing signals are used to generate pulses during 
the adjustment mode so that these adju stmen ts can be 
made while the device is in-circuit. The TEST line also 
contains a pull-up resistor, so adjustm ents can tae per- 
formed sim ply by grounding the TEST pin, oven-iding the 
pull-up. The TEST pin cannot t)e used to disable stepping 
rates during operation as its function is quite different from 
the 179X. 

Other pins on the device also include pull-up resistors and 
may lae l eft open to sat isfy a Logic 1 condition. These are: 
ENP, 5/8, ENMF, WPRT, and DDEN. 

GENERAL DISK READ OPERATIONS 

Sector lengths of 128, 256, 512 or 1024 are o btainable in 
either FM or MFM formats. For FM, DDEN should tie 
placed to logical "1." For MFM formats, DDEN should be 



Sector Length Table* 



Sector Length 
Field (hex) 



Numtier of Bytes 
in Sector (decimal) 



00 
01 
02 
03 



128 

256 

512 

1024 



* 2795/97 may vary — see command summary. 

placed to a logical "0." Sector lengths are determined at 
format time by the fourth byte in the "ID" field. 

The number of sectors per track as far as the 279X is con- 
cerned can be from 1 to 255 sectors. The number of tracks 
as far as the 279X is concerned is from to 255 tracks. For 
IBM 3740 compatibility, sector lengths are 128 bytes with 26 
sectors per track. For System 34 compatibility (MFM), 
sector lengths are 256 bytes/sector with 26 sectors/track; or 
lengths of 1024 bytes/sector with 8 sectors/track. 

GENERAL DISK WRITE OPERATION 

When writing is to take place on the diskette the Write Gate 
(WG) output is activated, allowing current to flow into the 
ReadAA/rite head. As a precaution to erroneous writing the 
first data byte must be loaded into the Data Register in 
response to a Data Request from the 279X before the Write 
Gate signal can be activated. 



Writing is inhibited when the Write Protect input is a logic 
low, in which case any Write command is immediately 
terminated, an interrupt is generated and the Write Protect 
status bit is set. 

For write operations, the 279X provides Write Gate (Pin 30) 
and .Write Data (Pin 31) outputs. Write data consists of a 
series of pulses set to a width approximately three times 
greater than the precomp adjustment. Write Data provides 
the unique address mari<s in both formats. 

READY 

Whenever a Read or Write command (Type II or III) is 
received the 297X samples the Ready input. If this input is 
logic low the command is not executed and an interrupt is 
generated. All Type I commands are performed regardless 
of the state of the Ready input Also, whenever a Type II or 
III command is received, the TG43 signal output is updated. 
TG43 may be tied to ENP to enable write precompensation 
on tracks 44-76. 

COMMAND DESCRIPTION 

The WD279X will accept eleven commands. Command 
words should only be loaded in the Command Register 
when the Busy status bit is off (Status bit 0). The one ex- 
ception is the Force interrupt corhmand. Whenever a 
command is tjeing executed, the Busy status bit is set. 
When a command is completed, an interrupt is generated 
and the Busy status bit is reset. The Status Register in- 
dicates whether the completed command encountered an 
error or was faulVfree. For ease of discussion, commands 
are divided into four types. Commands and types are 
summarized in Table 1. 







TABLE 1. 


COMMAND SUMMARY 




A. Commands for Models: 2791, 2793 














B. Commands for Models: 2795, 2797 
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Type Command 7 
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1 Restore 
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1 Seek 
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1 Step 





1 


T 


ti 


V 


ri 


ro 


1 T h V n 


ro 


1 Step-in 
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1 Step-out 
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II Read Sector 1 
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C 





1 m L E U 





II Write Sector 1 
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C 


ao 


1 1 m L E U 


ao 


III Read Address 1 


1 
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1 1 E U 





III Read Track 1 
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1 
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1 1 1 E U 





III Write Track 1 
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1 
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1 1 1 1 E U 





IV Force Interrupt 1 
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FLAG SUMMARY 



TABLE 2. FLAG SUMMARY 



Command 


Bit 








Type 


No<s) 




Description 




1 


0,1 


ri ro = Stepping Motor Rate 
See Table 3 for Rate Summary 






1 


2 


V = Track Number Verity Flag 


V = 0, No verify 

V = 1, Verify on destination track 




1 


3 


h = Head Load Flag 


h = 0, Unload head at beginning 
h =1, Load head at beginning 




1 


4 


T = Track Update Flag 


T = 0, No update 

T =1, Update track register 




II & III 





ao = Data Address Mark 


ao=0,FB(DAM) 

ao= 1,F8 (deleted DAM) 




II 


1 


C = Side Compare Flag 


C = 0, Disable side compare 
C = 1, Enable side compare 




II & III 


1 


U = Update SSO 


U =0, Update SSO too 
U = 1, Update SSO to 1 




II & III 


2 


E = 15 MS Delay 


E = 0, No. 15 MS delay 

E = 1,15 MS delay (30 MS fori MH;4 




II 
II 

II 


3 
3 

4 


S = Side Compare Flag 
L = Sector Length Flag 


S = 0, Compare for side 
S = 1, Compare for side 1 




LSB's Sector Length in ID Field 
00 01 10 11 


L =0 256 512 1024 


128 


L = 1 128 256 512 


1024 


m = Multiple Record Flag 


m = 0, Single record 
m = 1, Multiple records 




IV 


0-3 


Ix = Interrupt Condition Flags 

10 = 1 Not Ready To Ready Transition 

1 1 =1 Ready To Not Ready Transition 
'2 = 1 1ndex Pulse 

I3 = 1 1mmediate Interrupt, Requires A Reset* 
13-IC = Terminate With No Intermpt (INTRQ) 





"NOTE: See Type IV Command Description for further information. 
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Write Precompensation 

When operating in Double Density mode (DDEN = 0), the 
279X has the capability of providing a user-defined 
preconnpensation value for Write Data An external 
potentiometer (1 OK) tied to the WPW signal (Pin 33) allovi/s a 
setting of 100 to 300 ns from nominal. 

Setting the Write precomp value is accomplished by for- 
cing the TEST line (Pin 22) to a Logic 0. A stream of pulses 
can then be seen on the Write Data (Pin 31) line. Adjust the 
WPW Potentiometer for the desired pulse width. This 
adjustment may be performed in-circuit since Write Gate 
(Pin 30) is inactive while TEST = 0. 

Data Separation 

The 279X can operate with either an external data separator 
or its own internal recovery circuits. The condition of the 
TEST line (Pin 22) in conjunction with MR (Pin 19) will select 
internal or external mode. 

To program th e 279X for external VCO, a MR pulse must be 
applied while TEST = 0. A clock equivalent to eight times 
the data rate (e.g., 4.0 MHz for 8" Double Density) is applied 
to the VCO input (Pin 26). The feedback reference voltage is 
available on the Pump out put (P in 23) for external in- 
tegration to control the VCO. TEST is returned to a Logic 1 
for normal operation. Note:_Jo maintain this mode, TEST 
must be held low whenever MR is applied. 



For internal VCO operation, the TEST line must be high 
during the MR pulse, then set to a Logic for the ad- 
justment procedure. 

A 50K Potentiometer tied to the RPW input (Pin 18) is used 
to set the internal Read Data pulse for proper phasing. With 
a scope on Pin 29 (TG43), adjust the RPW pulse for 1/8 of 
the data rate (250 ns for 8" Double Density). An external 
variable capacitor of 5-60 pf is tied to the VCO input (Pin 26) 
for adjusting center frequency With a frequency counter 
on Pin 16 (DIRC) adjust the trimmer cap to yield the ap- 
propriate Data Rate (500 KHz for 8" Double Density). The 
DDEN line must be low while the 5/8 line is held high or the 
adjustment times above will tie doubled. 

After adjustments have tieen made, the TEST pin is 
returned to a Logic 1 and the device is ready for operation. 
Adjustments may be made in-circuit since the DIRC and 
TG43 lines may toggle without affecting the drive. 

The PUMP output (Pin 23) consists of positive and negative 
pulses, which their duration is equivalent to the phase 
difference of incoming Data vs. VCO frequency This signal 
is internally connected to the VCO input, but a Filter is 
needed to connect these pulses to a slow moving DC 
voltage. 

The intemal phase-detector is unsymmetrical for a random 
distribution of data pulses by a factor of two, in favor of a 
fHJMP UP condition. Therefore, it is desirable to have a 
PUMP DOWN twice as responsive to prevent run-away 
during a lock attempt. 

A first order lag-lead filter can be used at the PUMP output 
(Pin 23). This filter controls the instantaneous response of 
the VCO to bit-shifted data (jitter) as well as the response to 
nonnal frequency shift, i.e., the lock-up time. A balance 
must be accomplished between the two conditions to 
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inhibit over-responsiveness to jitter and to prevent an 
extremely wide lock-up response, leading to PUMP run- 
away The filter affects these two reactions in mutually 
opposite directions. 

The Source Impedance for a PUMP UP/DOWN condition is 
600/120 ohms, respectively, therefore the change in bias 
voltage for each pump can be approximated; 

dtAV dt = 250 ns. (set by RPW) 

RC C = O.Vf 

R = Rs -(- R 
AV = 2.6 V for PUMP UP 

0.9V for PUMP DOWN 

Look up response (Tl) is the transient time for the Loop to 
lock from center frequency (Fq) to maximum lock range: 

Tl = 10% FlxKqxAP 
Where: 
Ko = VCO Conversion Gain = 3.7KHz/mV 
Fl = Lock Range = 4.00 MHz 
A P = Change in Bias for each Pump = 4 mV/PUMP 

400 KHz x 3.7 KHz X 4 mV = 27 pumps 
27 pumps = 54(jsec = 3.4 Byte times (8" Double Density) 

The following Filter Circuit is recommended for 8" 

FM/MFM: 

PUMP <— 

(PIN 23) 1^;; 
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Since SVi " Drives operate at exactly one-half the data rate 
(250 Kb/sec) the atwve capacitor should be doubled to .2 or 
.22^,f. 

TYPE I COMMANDS 

The Type I Commands include the Restore, Seek, Step, 
Step-in, and Step-Out commands. Each of the Type I 
Commands contains a rate field (rg r-]), which determines 
the stepping motor rate as defined in Table 3. 

A 2).is (MFM) or 4 ^s (FM) pulse is provided as an output to 
the drive. For every step pulse issued, the drive moves one 
track location in a direction determined by the direction 
output. The chip will step the drive in the same direction it 
last stepped unless the command changes the direction. 

The Direction signal is active high when stepping in and 
low when stepping out. The Direction signal is valid 12 us 
before the first stepping pulse isgenerated. 

The rates (shown in Table 3) can be applied to a Step- 
Direction Motor through the device interface. 





TABLES 


STEPRNG RATES 




CLK 




2 MHz 


1MHz 


R1 RO 




TEST = 1 


TEST = 1 







3 ms 


6 ms 


1 




6 ms 


12 ms 


1 




10 ms 


20 ms 


1 1 




15 ms 


30 ms 



After the last directional step an additional 15 milliseconds 
of head settling time takes place if the Verify flag is set in 
Type I commands. Note that this time doubles to 30 ms for 



a 1 MHz clock. There is also a 15 ms head settling time if 
the E flag is set In any Type II or III command. 

When a Seek, Step or Restore command is executed an 
optional verification of Read-Write head position can be 
perfonned by setting bit 2 (V = 1) in the command word to 
a logic 1. The verification operation begins at the end of the 
15 millisecond settling time after the head is loaded against 
the media. The track number from the first encountered ID 
Field is compared against the contents of the Track 
Register. If the track numbers compare and the ID Field 
Cyclic Redundancy Check (CRC) is correct, the verify 
operation is complete and an INTRQ is generated with no 
errors. If there is a match but not a valid CRC, the CRC error 
status bit is set (Status bit 3), and the next encountered ID 
field is read from the disk for the verification operation. 

The WD279X must find an ID field with correct track 
number and correct CRC within 5 revolutions of the media; 
otherwise the seek error Is set and an INTRQ is generated. 
If V = 0, no verification is performed. 

The Head Load (HLD) output controls the movement of the 
read/write head against the media HLD is activated at the 
beginning of a Type I command if the h flag is set(h = 1), at 
the end of the Type I command if the verify flag (V = 1), or 
upon receipt of any Type II or III command. Once HLD is 
active it remains active until either a Type I command is 
received with (h = and V = 0); or if the 279X is in an idle 
state (non-busy) and 15 index pulses have occurred. 

Head Load timing (HLT) is an input to the 279X which is 
used for the head engage time. When HLT = 1, the 279X 
assumes the head is completely engaged. The head 
engage time is typically 30 to 100 ms depending on drive. 
The low to high transition on HLD is typically used to fire a 
one shot. The output of the one shot is then used for HLT 
and supplied as an input to the 279X. 



HLT (FROM ONE SHOT] 



HEAD LOAD TIMING 

When both HLD and HLT are tme, the 279X will then read 
from or write to the media. The "and" of HLD and HLT ap- 
pears as status Bit 5 in Type I status. 

In summary for the Type I commands: if h = and V = 0, 
HLD is reset. If h = 1 and V = 0, HLD is set at the 
beginning of the command and HLT is not sampled nor is 
there an internal 15 ms delay. If h = and V = 1 , HLD is set 
near the end of the command, an internal 15 ms occurs, 
and the 279X waits for HLT to be true. If h = 1 and V = 1, 
HLD is set at the beginning of the command. Near the end 
of the command, after all the steps have been issued, an 
Internal 15 ms delay occurs and the 279X then waits for HLT 
to occur. 

For Type II and III commands with E flag off, HLD is made 
active and HLT is sampled until true. With E flag on, HLD is 
made active, an internal 15 ms delay occurs and then HLT is 
sampled until true. 



RESTORE (SEEK TRACK 0) 

Upon receip t of th is command the Track 00 (TROO) input is 
sampled. If TROO is active low indicating the Read-Write 
head is positioned over track 0, the Track Regis ter is loaded 
with zeroes and an interrupt is generated. If TROO is not 
active low, stepping pulses (pins 15 to 16) at a rate specified 
by the 'VO field are issued until the TROO input is activated. 
At this time the Track Register is loaded with zeroes and an 
interrupt is generated. If the TROO input does not go active 
low after 255 stepping pulses, the 279X terminates 
operation, interrupts, and sets the Seek error status bit. A 
verification operation takes place if the V flag is set. The h 
bit allows the head to be loaded at the start of command. 
Note that the Restore command is executed when MR 
goes from an active to an inactive state. 
SEEK 

This command assumes that the Track Register contains 
the track number of the current position of the Read-Write 
head and the Data Register contains the desired track 
number The WD279X will update the Track register and 
issue stepping pulses in the appropriate direction until the 
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TYPE I COMMAND FLOW 

contents of the Track register are equal to the contents of 
the Data RGqister(the desired track location). A verification 
operation takes place if the V flag is on. The h bit allows the 
head to be loaded at the start of the command. An intemjpt 
is generated at the completion of the command. Note: 
When using multiple drives, the track register must be 
updated for the drive selected tiefore seeks are issued. 

STEP 

Upon . receipt of this command, the 279X issues one 
stepping pulse to the disk drive. The stepping motor 
direction is the same as in the previous step command. 
After a delay determined by the ^^'0 field, a verification 
takes place if the V flag is on. If the T flag is on, the Track 
Register is updated. The h bit allows the head to be loaded 
at the start of the command. An interrupt is generated at 
the completion of the command. 

STEP-IN 

Upon receipt of this command, the 279X issues one 
stepping pulse in the direction towards track 76. If the T 
flag is on, the Track Register is incremented by one. After a 
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TYPE I COMMAND FLOW 

delay determined by the H '0 field, a verification takes place 
if the V flag is on. The h bit allows the head to be loaded at 
the start of the command. An interrupt is generated at the 
completion of the command. 

STEP-OUT 

Upon receipt of this command, the 279X issues one 

stepping pulse in the direction towards track 0. If the T flag 

is on, the Track Register is decremented by one. After a 

delay determined by the '■['Q field, a verification takes place 

if the V flag is on. The h bit allows the head to be loaded at 

the start of the command. An interrupt is generated at the 

completion of the command. 

EXCEPTIONS 

On the 2795f7 devices, the SSO output is not affected 

during Type I commands, and an intemal side compare 

does not take place when the (V) Verify Flag is on. 

TYPE II COMMANDS 

The Type II Commands are the Read Sector and Write 

Sector commands. Prior to loading the Type II Command 

into the Command Register, the computer must load the 



Sector Register with the desired sector number Upon 
receipt of the Type II command, the busy status Bit is set. If 
the E flag = 1 (this is the normal case) HLD is made active 
and HLT is sampled after a 15 msec delay If the E flag is 0, 
the head is loaded and HLT sampled with no 15 msec delay 

When an ID field is located on the disk, the 279X compares 
the Track Number on the ID field with the Track Register If 
there is not a match, the next encountered ID field is read 
and a comparison is again made. If there was a match, the 
Sector Number of the ID field is compared with the Sector 
Register If there is not a Sector match, the next en- 
countered ID field is read off the disk and comparisons 
again made. If the ID field CRC is correct, the data field is 
then located and will be either written into, or read from 
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TYPE II COMMAND 

depending upon the command. The 279X must find an ID 
field with a Track number, Sector number, side number, and 
CRC within 5 revolutions of the disk; otherwise, the Record 
not found status bit is set (Status bit 4) and the command is 
terminated with an interrupt. 

Each of the Type II Commands contains an (m) flag which 
determines if multiple records (sectors) atB to be read or 
written, depending upon the command. If m = 0, a single 
sector is read or written and an interrupt is generated at the 
completion of the command. If m = 1, multiple records are 
read or written with the sector register internally updated 
so that an address verification can occur on the next 
record. The 279X will continue to read or write multiple 
records and update the sector register in numerical 
ascending sequence until the sector register exceeds the 
number of sectors on the track or until the Force Interrupt 
command is loaded into the Command Register, which 
temninates the command and generates an intemjpt. 

For example: If the 279X is instmcted to read sector 27 and 
there are only 26 on the track, the sector register exceeds 
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TYPE II COMMAND 

the number available. The 279X will search for 5 disk 
revolutions, intentipt out, reset busy, and set the record not 
found status bit. 

The Type II commands for 2791-93 also contain side select 
compare flags. When C = (Bit 1) no side comparison is 
made. When C = 1, the LSB of the side number is read off 
the ID Field of the disk and compared with the contents of 
the (S) flag (Bit 3). If the S flag compares with the side 
number recorded in the ID field, the 279X continues with 
the ID search. If a comparison is not made within 5 index 
pulses, the intemapt line Is made active and the Record- 
Not-Found status bit is set. 

The Type II and III commands for the 2795-97 contain a side 
select flag (Bit 1). When U = 0, SSO is updated to 0. 
Similarly, U = 1 updates SSO to 1. The chip compares the 
SSO to the ID field. If they do not compare within 5 
revolutions the intemipt line is made active and the RNF 
status bit is set. 

The 2795/7 READ SECTOR and WRITE SECTOR com- 
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WRITE SECTOR 
SEQUENCE 
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DELAY 11 BYTES 
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OF WHITE COMMAND 



DR TO DSR SET ORO 



WRITE BYTE TO DISK 




SET DATA 

LOST 

WRITE BYTE 

OF 2£H0S 
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TURN OFF WG 



TYPE II COMMAND 

mands include a 'L' flag. The 'L' flag, in conjunction with 
the sector length byte of the ID Field, allows different byte 
lengths to tie implemented in each sector For IBM com- 
patibility, the 'L' flag should be set to a one. 

READ SECTOR 

Upon receipt of the Read Sector command, the head is 
loaded, the Busy status bit set, and when an ID field is 
encountered that has the correct track numtjer, correct 
sector number, correct side numtier, and correct CRC, the 
data field is presented to the computer. The Data Address 
Mark of the data field must be found within 30 bytes in 
single density and 43 bytes in double density of the last ID 
field CRC byte; if not, the ID field search is repeated. 

When the first character or byte of the data field has been 
shifted through the DSR, it is transferred to the DR, and 
DRQ Is generated. When the next byte is accumulated in 
the DSR, it is transferred to the DR and another DRQ is 
generated. If the Computer has not read the previous 
contents of the DR before a new character is transferred 



that character is lost and the Lost Data Status bit is set. 
This sequence continues until the complete data field has 
been inputted to the computer. If there is a ORG error at the 
end of the data field, the CRC error status bit is set, and the 
command is terminated (even if it is a multiple sector 
command). 

At the end of the Read operation, the type of Data Address 
fi/lark encountered in the data field is recorded in the Status 
Register (Bit 5) as shown; 

STATUS 
BITS 

1 Deleted Data Marl< 

Data Marl< 

WRITE SECTOR 

Upon receipt of the Write Sector command, the head is 
loaded (HLD active) and the Busy status bit is set. When an 
ID field is encountered that has the correct track number, 
con-ect sector number, correct side number, and correct 
CRC, a DRQ is generated. The 279X counts off 11 bytes in 
single density and 22 bytes in double density from the CRC 
field and the Write Gate (WG) output is made active if the 
DRQ Is serviced (i.e., the DR has been loaded by the 
computet). If DRQ has not been serviced, the command is 
terminated and the Lost Data status bit is set. If the DRQ 
has been serviced, the WG is made active and six bytes of 
zeroes in single density and 12 bytes in double density are 
then written on the disk. At this time the Data Address 
Mark is then written on the disk as detemnined by the ao 
field of the command as shown below: 



ao 



Data Address lvlari< (Bit 0) 



Deleted Data Mari< 
Data Mark 



The 279X then writes the data field and generates DRQ's to 
the computer. If the DRQ is not sen/Iced in time for con- 
tinuous writing the Lost Data Status Bit is set and a byte of 
zeroes is written on the disk. The command is not ter- 
minated. After the last data byte has been written on the 
disk, the two-byte CRC is computed internally and written 
on the disk followed by one bye of FE in FM or in MFM. The 
WG output is then deactivated. For a 2 MHz clock the 
INTRQ will set 8 to 12 usee after the last CRC byte is 
written. For partial sector writing, the proper method is to 
write the data and fill the t>alance with zeroes. By letting the 
chip fill the zeroes, errors may tie masked by the lost data 
status and improper CRC Bytes. 

TYPES III COMMANDS 
READ ADDRESS 

Upon receipt of the Read Address command, the head is 
loaded and the Busy Status Bit is set. The next en- 
countered ID field is then read iri from the disk, and the six 
data bytes of the ID field are assembled and transferred to 
the DR, and a DRQ Is generated for each byte. The six bytes 
of the ID field are shown below: 



TRACK 
ADDR 


SIDE 
NUMBER 


SECTOR 
ADDRESS 


SECTOR 
LENGTH 


CRC 

1 


CRC 
2 


1 


2 


3 


4 


5 


6 




SET BUSY. RESET DRQ, 

LOST DATA. STATUS 

BtTS «, 5 
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< INTRO ^ 

RESET BUSY J 
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Although the CRC characters are transferred to the 



TYPE III COMMAND WRITE TRACK 

computer, the 279X checks for validity and the CRC error 
status bit is set if there is a CRC error. The Track Address of 
the ID field is written into the sector register so that a 
comparison can be made by the host. At the end of the 
operation an interrupt is generated and the Busy Status is 
reset. 

READ TRACK 

Upon receipt of the READ track command, the head is 
loaded, and the Busy Status bit is set. Reading starts with 
the leading edge of the first encountered index pulse and 
continues until the next index pulse. All Gap, Header, and 
data bytes are assembled and transferred to the data 
register and DRQ's are generated for each byte. The ac- 
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TYPE III COMMAND WRITE TRACK 



cumulation of bytes is synchronized to each address nnark 
encountered. An interrupt is generated at the completion of 
the command. 

This command has several characteristics which mal<e it 
suitable for diagnostic purposes. They are; no CRC 
checking is performed; gap Information is included in the 
data stream; the Internal side compare is not performed; 
and the address mark detector is on for the duration of the 
command. Because the A.M. detector is always on, write 
splices or noise may cause the chip to look for an A. fvl. If an 
address mark does not appear on schedule with the Lost 
Data status flag being set. 

The ID A.M., ID field, ID CRC bytes, DAM, Data and Data 
CRC Bytes for each sector will tie correct. The Gap Bytes 
may be read incorrectly during write-splice time because of 
synchronization. 

WRITE TRACK FORMATTING THE DISK 

(Refer to section on Type III commands for flow diagrams.) 

Formatting the disk is a relatively simple task when operat- 
ing programmed 1/0 or when operating under DK/IA with a 
large amount of memory. Data and gap Information must be 
provided at the computer Interface. Formatting the disk is 
accomplished by positioning the RAW head over the de- 
sired track number and issuing the Write Track command. 

Upon receipt of the Write Track command, the head is 
loaded and the Busy Status bit is set Writing starts with 
the leading edge of the first encountered index pulse and 
continues until the next Index pulse, at which time the 
interrupt is activated. The Data Request is activated Im- 
mediately upon receiving the command, but writing will not 
start until after the first byte has been loaded into the Data 
Register. If the DR has not been loaded by the time the 
index pulse is encountered the operation is terminated 
making the device Not Busy, the Lost Data Status Bit Is set, 
and the interrupt is activated. If a byte is not present in the 
DR when needed, a byte of zeroes is substituted. 

This sequence continues from one index mark to the next 
index mark. Normally, whatever data pattern appears in the 
data register is written on the disk with a normal clock 
pattern. However, if the 279X detects a data pattern of F5 
thai FE in the data register, this is interpreted as data ad- 
dress marks with missing clocks or CRC generation. 

The CRC generator Is initialized when any data byte from 
F8 to FE is alaout to be transferred from the DR to the DSR 



CONTROL BYTES FOR INITIALIZATION 



. DATA PATTERN 
IN DR (HEX) 


WD279X INTERPRETATION 


WD279X INTERPRETATION 


IN FM (DDEN = 1) 


IN MFM (DDEN = 0) 


00 thru F4 


Write 00 thm F4 with CLK = FF 


Write 00 thru F4, in MFM 


F5 


Not Allowed 


Write A1 * in MFM, Preset CRC 


F6 


Not Allowed 


WriteC2**inMFM 


F7 


Generate 2 CRC bytes 


Generate 2 CRC bytes 


F8 thru FB 


Write F8 thru FB, Clk = C7, Preset CRC 


Write F8 thru FB, in MFM 


PC 


Write FC with Clk= D7 


Write FC in MFM 


FD 


WriteFDwithClk= FF 


Write FD in MFM 


FE 


Write FE, Clk = C7, Preset CRC 


Write FE in MFM 


FF 


WriteFFwithClk = FF 


Write FF in MFM 



' Missing clock transition between bits 4 and 5 



•Missing clock transition between bits 3 and 4 



or by receipt ot F5 in MFM. An F7 pattern will generate two 
CRC characters in FM or MFM. As a consequence, the 
patterns F5 thru FE must not appear in the gaps, data 
fields, or ID fields. Also, CRC's must be generated by an F7 
pattern. 

Disks may be tonnatted in IBM 3740 or System 34 formats 
with sector lengths of 128, 256, 512, or 1024 bytes. 

TYPE IV COMMANDS 

The Forced Inten-upt command is generally used to ter- 
minate a multiple sector read or write command or to in- 
sure Type I status in the status register This command can 
be loaded into the command register at any time. If there is 
a current command under execution (busy status bit set) 
the command will be terminated and the busy status bit 



reset. 

The lower four bits of the command determine the condi- 
tional interrupt as follows: 

lo = Not-Ready to Ready Transition 

H = Ready to Not-Ready Transition 

'2 = Every Index Pulse 

I3 = Immediate Interrupt 

The conditional interrupt is enabled when the correspond- 
ing bit positions of the command (I3 - 'O) are set to a 1. 
Then, when the condition for interrupt is met, the INTRQ 
line will go high signifying that the condition specified has 
occur^ed. If '3 - Iq are all set to zero (HEX DO), no interrupt 
will occur but any command presently under execution will 
be immediately terminated. When using the immediate 
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interrupt condition l3 = 1), an interrupt will be immediately 
generated and the current command terminated. Reading 
the status or writing to the command register will not auto- 
matically clear the interrupt. The HEX DO is the only com- 
mand that will enable the immediate interrupt (HEX 08) to 
clear on a subsequent load command register or read sta- 
tus register operation. Follow a HEX D8 with DO command. 
Wait 8 micro sec (double density) or 16 micro sec (single 
density) before issuing a new command after issuing a 
forced inten-upt (times double when clock = 1 MHz). 
Loading a new command sooner than this will nullify the 
forced interrupt. 

Forced interrupt stops any command at the end of an in- 
ternal micro-instruction and generates INTRQ when the 
specified condition is met. Forced interrupt will wait until 
ALU operations in progress are complete (CRC 
calculations, compares, etc.) 

More than one condition may be set at a time. If for 
example, the READY TO NOT-READY condition (ll = 1) 
and the Every Index Pulse (l2 = 1) are both set, the 
resultant command would be HEX "DA." The "OR" func- 
tion is perfonned so that either a READY TO NOT-READY 
or the next Index Pulse will cause an interrupt condition. 



STATUS REGISTER 

Upon receipt of any command, except the Force Interrupt 
command, the Busy Status bit is set and the rest of the 
status bits are updated or cleared for the new command. If 
the Force Interrupt Command is received when there is a 
cunent command under execution, the Busy status bit is 
reset, and the rest of the status bits are unchanged. If the 
Force Interrupt command is received when there is not a 
current command under execution, the Busy Status bit is 
reset and the rest of the status bits are updated or cleared. 
In this case. Status reflects the Type I commands. 
The user has the option of reading the status register 
through program control or using the DRQ line with DMA or 
intermpt methods. When the Data register is read the DRQ 
bit in the status register and the ORG line are automatically 
reset. A write to the Data register also causes both DRQ's 
to reset. 

The busy bit in the status may be monitored with a user 
program to determine when a command is complete, in lieu 
of using the INTRQ line. When using the INTRQ, a busy 
status check is not recommended because a read of the 
status register to determine the condition of busy will reset 
the INTRQ line. 




READ ADDRESS 
SEQUENCE 




TYPE III COMMAND 

Read Track/Address 



The format of the Status Register is shown below: 



(BITS) 


7 


6 


5 


4 


3 


2 


1 





S7 


86 


S5 


S4 


S3 


S2 


S1 


SO 



Status varies according to the type of command executed 
as shown in Table 4. 

Because of internal sync cycles, certain time delays must 
be obsen/ed when operating under programmed I/O. They 
are: (times double when clock = 1 MH;^ 



Operation 


Next Operation 


Delay Req'd. 
FM " ! MFM 


Write to 
Command Reg. 


Read Busy Bit 
(Status Bit 0) 


12^s ] 6ms 


Write to 
Command Reg. 


Read Status 
Bits 1-7 


28^48 ] 14^(3 


Write Any 
Register 


Read From Diff. 
Register 


; 



IBM 3740 FORMAT — 128 BYTES/SECTOR 

Shown below is the IBM single-density fonnat with 128 
bytes/sector. In order to format a diskette, the user must 
issue the Write Track command, and load the data register 
with the following values. For every byte to be written, there 
is one Data Request. 



NUMBER 


HEX VALUE OF 


OF BYTES 


BYTE WRITTEN 


40 


FF (or 00)3 


6 


00 


1 


FC (Index Mark) 


1 26 


FF(orOO) 




6 


00 




1 


FE (ID Address Mark) 




1 


Track Number 




1 


Side Number (00 or 01) 




1 


Sector Number (1 thru 1 A) 




1 


00 (Sector Length) 




1 


F7 (2 CRC's written) 




11 


FF(orOO) 




6 


00 




1 


FB (Data Address Mark) 




128 


Data (IBM uses E5) 




1 


F7 (2 CRC's written) 




27 


FF(orOO) 


2472 


FF(orOO) 



issue the Write Track command and load the data register 
with the following values. For every byte to be written, there 
is one data request. 



1. Write bracketed field 26 times 

2. Continue writing until 279X interrupts out. 
Approx. 247 bytes. 

3. A '00' option is allowed on 2795/7 only. 



IBM SYSTEM 34 FORMAT- 
256 BYTESSECTOR 

Shown below is the IBM dual-density format with 256 
bytes/sector. In order for format a diskette the user must 



NUMBER 


HEX VALUE OF 


OF BYTES 


BYTE WRITTEN 


80 


4E 


12 


00 


3 

1 

* 50 


F6 (Writes C2) 
FC (Index Mark) 
4E 




12 


00 




3 

1 
1 
1 
1 
1 
1 
22 


F5 (Writes A1) 
FE (ID Address Mark) 
Track Number (0 thru 4C) 
Side Number (0 or 1) 
Sector Numt>er(1 thru 1A) 
01 (Sector Length) 
F7 (2 CRCs written) 
4E 




12 


00 




3 

1 

256 


F5 (Writes A1) 

FB (Data Address Mark) 

DATA 




1 

54 

598** 


F7 (2 CRCs written) 

4E 

4E 



3S 

o 

lO 
CO 

X 

o 

to 



* Write bracketed field 26 times 
* * Continue writing until 279X interrupts out. 
Approx. 598 bytes. 




IBM TRACK FORMAT 



o 

to 
to 

B 

O 

ro 



1. NON-IBM FORMATS 

Variations in the IBM formats are possible to a limited ex- 
tent if the following requirements are met: 

1) Sector size must be 128, 256, 512 of 1024 bytes. 

2) Gap 2 cannot be varied from the IBM format. 

3) 3 bytes of A1 must be used in MFM. 

In addition, the Index Address Mark is not required for 
operation by the 279X. Gap 1, 3, and 4 lengths can be as 
short as 2 bytes for 279X operation, however PLL lock up 
time, motor speed variation, write splice area, etc. will add 
more bytes to each gap to achieve proper operation. It is 
recommended that the IBM format be used for highest 
system reliability. 





FM 


MFM 


Gapl 


16 bytes FF 


32 bytes 4E 


Gap II 


11 bytes FF 


22 bytes 4E 


* 


6 bytes 00 


12 bytes 00 


ft 




3 bytes A1 


Gap III*" 


10 bytes FF 


24 bytes 4E 




4 bytes 00 


8 bytes 00 
3 bytes A1 


Gap IV 


16 bytes FF 


16 bytes 4E 



* Byte counts must be exact. 

' Byte counts are minimum, except exactly 3 bytes of A1 
must be written. 



ELECTRICAL CHARACTERISTICS 

Absolute Maximum Ratings 

Voltage to any input with 
respect to Vss = +15to -0.3V 

C|N & CouT = 15 pF max with all pins grounded except 

one under test. 

Operating temperature = 0°Cto70°C 

Storage temperature = -55°Cto +125°C 

OPERATING CHARACTERISTICS (DC) 

TA = 0°Cto70''C,Vss = OV.VcC = +5M ± .25V 



NOTE: Maximum limits indicate where permanent device 
damage occurs. Continuous operation at these limits is not 
intended and should be limited to those conditions 
specified in the DC Electrical characteristics. 



SYMBOL 


CHARACTERISTIC 


MIN. 


TYP. 


MAX. 


UNITS 


CONDITIONS 


l|L 


Input Leakage 






10 


^JK 


V|N = VCC 


lOL 


Output l.^akage 






10 


^ 


VOUT = VcC 


V|H 


Input High Voltage 


2.0 






V 




V|L 


Input Low Voltage 






0.8 


V 




vqh 


Output High Voltage 


2.4 






V 


l0= -100mA 


Vol 


Output Low Voltage 






0.45 


V 


IO= 1.6 mA 


VOHP 


Output High PUMP 


2.2 






V 


Iqp = -1.0 mA 


VoLP 


Output Low PUMP 






0.2 


V 


Iqp = -H.OmA 


pd 


Power Dissipation 






.75 


w 


All Outputs Open 


Rpu 


Internal Pull-up* 


100 




1700 


mA 


V|N = OV 


Ice 


Supply Current 




70 


150 


mA 


All Outputs Open 



" Internal Pull-up resistors on PINS 1, 17, 22, 25, 37, and 40. 



TIMING CHARACTERISTICS 

Ta = 0°Cto70°C,Vss = ov.vcc ■■ 
READ ENABLE TIMING 



+ 5V ± .25V 



SYMBOL 


CHARACTERISTIC 


MIN. 


TYP. 


MAX. 


UNITS 


CONDITIONS 


TSET 


Setup ADDR & CS to RE 


50 






nsec 




thld 


HoldADDR&CSfromRE 
RE Pulse Width 


10 






nsec 




Tre ' 


200 






nsec 


Cl = 50 pf 


Tdrr 


DRQ Reset from RE 




100 


200 


nsec 




TjRR 


INTRQ Reset from RE 




500 


3000 


nsec 


See Note 


tdacc 


DataValidfromRE 




100 


200 


nsec 


Cl = 50 pf 


tdoh 


DataHoldFromRE 


20 




150 


nsec 


Cl = 50 pf 



o 

K5 
■SI 

CO 

X 
o 

IfO 



WRITE ENABLE TIMING 



SYNPBOL 


CHARACTERISTIC 


MIN. 


TYP. 


MAX. 


UNITS 


CONDITIONS 


TSET 


Setup ADDR &CS to WE 


50 






nsec 




Thld 


Hold ADDR & CS from WE 


10 






nsec 




TWE 


WE Pulse Widtti 


200 






nsec 




Tdrr 


DRQ Reset from WE 




100 


200 


nsec 




T|RR 


INTRQ Reset from WE 




500 


3000 


nsec 


See Note 


tds 


Data Setup to WE 


150 






nsec 




tdh 


Data Hold from WE 


50 






nsec 





rNTRO ^ 




-•■ rpo n i an „ 



NOTE • CS MAT BE PERUANENTlv TIED LOW ft DCStREO 
■TIME OOUBlES WMCN CLOCtt ■ 1MM» 

t SEflWICE (WOftST CASEl 
■FM 27 5uS 
-MFM iSSiiS 

OnO RISING EDGE: IMDfCATCS THAT THE DATA HEGISTEn HAS ASSCMBLEO 

DATA 

DW) FALLING EDGE: INDICATES THAT THE DATA nEGtSTCfi WAS READ 

INTRQ RISING EDGE: OCCURS AT END OF COMMAND 

INTRO FAU.ING EDGE: (HOICATES THAT THE STATUS REGISTCB WAS READ, 




NOTE 1 CS MAY BE PEHMANENTLY TIED LOW IF DESIRED 

2 WHEN WRITING DATA WTO SECTOR TRACK OR DATA 
REGISTER USER CANNOT HEAD THIS REGtSTEH UNTIL 
AT UAST 4 -SEC Hi MFM AFTER THE RISING EDGE OF WE 
WHEN WRITttIG INTO THE COMMMJD REGISTER STATUS 
'J^'^^'iSl '?°"^^ ^*^^' IS WDT VALID UtfriL SOME » ^SEC IN FM. U ^SEC N MFM 

.^=., '^^ 'i^ LATER, THESE TIMES ARE DOUBLED WHEN CLK - 1 MHz 

MFM 11 5oS -TIME DOUBLES WHEN CLOCK - »AHX 

DRQ niSIHG EDGE: INOICATCS THAT THE DATA REQISTEH IS EMPTY 
DRQ FALLING EDGE: INDICATES THAT THE DATA REGISTER tS LOADED 
INTRO RISING EDGE: INDICATE THE END OF A COMMAND 
INTRQ FALLING EDGE: INDtCATES THAT THE COMMAND REGISTER 
15 WRITTEN TO 



READ ENABLE TIMING 



WRITE ENABLE TIMING 



INPUT DATA TIMING 



o 

to 

X 

a 

o 

IIS3 



SYMBOL 



CHARACTERISTIC 



MIN. 



TYP. 



MAX. 



UNITS 



CONDITIONS 



TPW 

tbc 



Raw Read Pulse Width 
Raw Read Cycle Time 



100 
1500 



200 
2000 



nsec 
nsec 



WRITE DATA TIMING: (ALL TIMES DOUBLE WHEN CLK = 1 MHz) 



SYMBOL 



CHARACTERISTIC 



MIN. 



TYP. 



MAX. 



UNITS 



CONDITIONS 



TWP 
TWG 
TWF 



Write Data Pulse Width 
Write Gate to Write Data 
Write Gate off from WD 



400 
240 



500 

2 
1 

2 
1 



600 
1000 



nsec 
nsec 
(jsec 
fisec 
|jsec 
fjsec 



FM 
MFM 

FM 
MFM 

FM 
MFM 



MISCELLANEOUS TIMING: 



SYMBOL 


CHARACTERISTIC 


MIN. 


TYP. 


MAX. 


UNITS 


CONDITIONS 


TCDi 


Clock Duty (low) 


230 


250 


20000 


nsec 




TCD2 


Clock Duty (high) 


230 


250 


20000 


nsec 




TSTP 


Step Pulse Output 


2or4 






/jsec 


See Note 


tdir 


DirSetuptoStep 




12 




Msec 


± CLK ERROR 


Tmr 


Master Reset Pulse Width 


50 






iisec 




Tip 


Index Pulse Width 


10 






usee 


See Note 


RPW 


Read Window Pulse Width 










Input 0-5V 






120 




700 


nsec 


MFM 






240 




1400 


nsec 


FM + 15% 


WPW 


Write Data Pulse Width 










Input 0-5V 






300 


500 


1000 


nsec 
nsec 


MFM 
FM 




Precomp Adjust. 


1(X) 




250 


nsec 


MFM 


RPW 


Read Window Pulse Width 










Input 0-5V 






120 




700 


nsec 


MFM 






240 




1400 


nsec 


FM ± 15% 


WPW 


Write Data Pulse Width 










Input 0-5V 






300 


500 


1000 


nsec 
nsec 


MFM 
FM 




Precomp Adjust. 


100 




250 


nsec 


MFM 


vco 


Free Run Voltage Controlled 


6.0 






MHz 


ExLC = 




Oscillator. Adjustable by ext. 




4.0 




MHz 


Ext.C = 35pf 




capacitor on Pin 26 














Pump Up + 25% 


5.0 






MHz 


PU = i2VCext 


VCD 


Pump Down -25% 






3.0 


MHz 


= 35pf 

PD=: 0.2V Cext 

= 35pf 


VCO 


5% Change Vqc 


3.8 




4.2 


MHz 


Cext = 35 pf 


Ta = 75X 


3.5 






MHz 


Cext = 35pf 


Cext 


Necessary external capacitor 


10 


35 


80 


pf 


VCO = 4.0MHz 
nom 


ROLK 


Derived read clock 
= VCO -4- 8, 16, 32 




500 




KHz 


VCO = 4.0MHz 


DDEN = 














5/8= 1 








250 




KHz 


DDEN = 

&8 = 








250 




KHz 


DDEN = 1 

58 = 1 








125 




KHz 


DDEN = 1 
58 = 


PU/DON 


PU/PDtimeon 






250 


ns 


MFM 




(pulse width) 






500 


ns 


FM 



APPENDIX G 
FLOPPY DISK ERROR CODES 



JMmA. STATUS REGISTER SUMMARY 





ALL TYPE! 


READ 


READ 


READ 


WRITE 


WRITE 


BIT 


COMMANDS 


ADDRESS 


SECTOR 


TRACK 


SECTOR 


TRACK 


S7 


NOT READY 


NOT READY 


NOT READY 


NOT READY 


NOT READY 


NOT READY 


S6 


WRITE 
PROTECT 











WRITE 
PROTECT 


WRITE 
PROTECT 


S5 


HEAD LOADED 





RECORD TYPE 











84 


SEEK ERROR 


RNF 


RNF 





RNF 





S3 


CRC ERROR 


CRC ERROR 


CRC ERROR 





CRC ERROR 





S2 


TRACK 


LOST DATA 


LOST DATA 


LOST DATA 


LOST DATA 


LOST DATA 


SI 


INDEX PULSE 


DRQ 


DRO 


DRQ 


DRQ 


DRQ 


SO 


BUSY 


BUSY 


BUSY 


BUSY 


BUSY 


BUSY 



STATUS FOR TYPE I COMMANDS 



BIT NAME 



MEANING 



S7 NOT READY 

(MI 



This bit when set indicates the drive is not ready. When reset it indicates that the drive is ready. 
This bit is an inverted copy of the Ready input and logically 'ored' with MR. 



S6 PROTECTED (30 When set. Indicates Write Protect is activated. This bit is an inverted copy of WRPT input. 



S5 HEAD LOADED 
(20) 



When set, it indicates the head is loaded and engaged. This bit is a logical "and" of HLD and HLT 
signals. 



S4 SEEK ERROR v 1 ' When set, the desired track was not verified. This bit is reset to when updated. 



S3CRCERR0R(4) 



CRC encountered in ID field. 



S2 TRACK 00 



(3) 



Tn 



When seL indicates Read/Write head is positioned to Track 0. This bit is an inverted copy of the 
TROO inpuL 



SI INDEX 



When set, indteates index mark detected from drive. This bit is an inverted copy of the IP input. 



SO BUSY 



(1) 



When set command is in progress. When reset no command is in progress: 



1. In certain cases the SUPER SIX must be run at 4MHz. This is 
because timing on the S-100 bus is critical when interfacing with 
select other S-1 00 bus boards. 



For the users of Super Six computer t>oard the following 
changes apply to any Super Six up to Rev. "M" ; 



1. Add a 1 K Resistor (pull up) to the 
BRQ output of 021 (D.M.A. ) . 

2- Change the value of Rll and R16 from 

1 K each to 2 K, for more V.C.O. range. 

3. Connect Phantom to U33 pin 1, for all memory 
to be turned OFF when active. 

And for Super Six users running at 6 MHZ with up to 
Rev. "M" board, using any other non Advanced Digital 
boards that has one or the two next characteristics. 

1. An I/O board latches the incoming data on 
the falling edge* of (pWR*) during an I/O 
transfer of data. 

2. A memory transfer where the signal (pSTVAL*) 
is expected to fall inside of (PSYNC) active. 

Modify your Super Six, through all the rework instructions, 
else do only first three steps. 



Rework Instructions: 

1„ Locate U15 on the solder side, connect a 1 K 
resistor across from U15 pin 14 to U15 pin 9. 



2. Remove Rll and R16 next to (L.E„D.l) both a 
1 K and replace with a 2 K resistor for Rll 
and R16 . 



Locate U33 on the solder side cut trace between 
U33 pin 1 and 2 and jumper from U33 pin 1 to U33 
pin 10. 



4- Locate U71 on the solder side and between pin 1 

and 20 cut trace to the feed through. Now install 
a 14 pin socket at Ul (spare ic) with pin 1 on 1 
jumper pin 7 of the socket to hole number 8, for 
ground into the IC. Jumper U71 pin 8 to Ul pin 
9. Locate U68 on solder side, jumper U68 pin 2 
to Ul pins 12 and 13. Locate U6 and jumper pin 11 
to Ul pin 11. Locate U6A and jumper pin 3 to Ul 
pin 10. Remove I.C. U6A (741S32) and lift pin 1, 
bend it so won't sort out. Jumper pin 1 to pin 4 
on component side over I.C, install back I.C. 
on solder side jumper U6A pin 2 to U25 Pin 4. 



Locate U2 8 component side, lift I.C. and pull oCflfe 
pin 9 install back I.C. Locate U4 and U5 solder side. 
Jvunper U4 pin 12 to U5 pin 13. Jumper U5 pin 12 to 
Ul pin 2 and 1. Jumper U4 pin 10 to Ul pin 5. Jumper 
01 pin 3 to 02 pin 1. Locate 021 (D,.M.A. ) jumper 021 
pin 12 to Ul pin 4- 



Install a 74S74 in Ul socket. 



APPEMDIX 1 
WARRANTY LETTER 




^ AOmNCED 
DIGITAL 

CORPORATION, 



WARRANTY NOTICE 



Advanced Digital Corporation new requires a Return Authorization 
Number for the return of any equipment for repair or credit. This 
nuttber will be issued by the Cus toner Support Etepartment. Any 
equipment received without the Return Authorization Number clearly 
marked on the outside of the package may be subject to significant 
delays in the repair process. 

Return Authorization Niinb)ers are active for 30 days after they are 
issued. If the equipment specified in the Return Authorization is 
not received by Advanced Digital within this 30 day period signi- 
ficant delays in handling the repair nay be incurred. 

If the equipment must be returned a second time, a new Return 
Authorization Number must be issued. Reuse of Return Authorization 
Numbers may result in delays in processing returns. 

Effective November 1, 1981, repair of all kit and nonwarranty 
boards will be $70.00. This fee is subject to change without 
notice. 

Returns for credit will be si±)ject to a 15% restocking charge. If 
material for credit was purchased through a dealer. Advanced Digital 
cannot issue a credit. Adjustment must be handled through the dealer. 
Other credit returns shovild have reference to the original invoice 
nurtiber. 

If you have any questions regarding special handling, packaging of 
the equipment, or procedures for returning equipment, please contact 
the Advanced Digital Corporation. 



The warranty on the svper §ix is one year from the date of purchase. 
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ADVANCED DIGITAL 




SUPER SIX SINGLE BOARD COMPUTER PARTS LIST 
ITEM PART NO. LOCATION QTY. 

1 

3 

1 

2 

2 

2 
I 

1 

2 
1 
2 
1 
1 
2 
2 
I 
1 
1 
I 
I 

r 

1 
1 

1 

1 
1 
1 
I 
1 
1 
1 
1 
1 

2 
1 
1 

18 

■ 1 

I 

3 

i- 

1 

. 2 



1 


74S 10 


U2 


2 


74LS00 


U3, Ull, U44 


3 


74LS132 


U4 


i^ 


74LS04 


U5, U68 


5 


74S74 


U6, U28 


6 


74LS32 


U6-A, U40 


7 


Z80B PIO 


U7 


8 


CD4098 


U8 


9 


74LS138 


U9, U34 


10 


7438 


UiO 


11 


74LS13 


U12, U33 


12 


74LS123 


U13 


13 


74LS14 


U14 


1^ 


7407 


U15, U22 


15 


16L8 


U16, U36 


16 


74LS174 


U17 


17 


74LS11 


Ui8 


18 


74S04 


U19 


19 


Z80B CTC 


U20 


20 


Z80DMA 


U21 


21 


74LS92 


U23 


22 


74LS393 


U24 


23 


8T97 


U25 


24 


7406 


U26 


25 


WD2793 


U27 


26 


2726 EPROM 


U29 


27 


Z80B 


U30 


28 


BR1945 


U31 


29 


74LS109 


U32 


30 


74LS27 


U35 


31 


74S287 


U37 


32 


Z80B DART 


U38 


33 


74LS280 


U39 


35 


8T98 


U43, U66 


36 


TTLDMIOO 


U41 


37 


74LS02 


U42 


38 


4164-15 


U46-U54 


39 


74LS244 


U65 


1^0 


74LS374 


U67 


41 


74LS240 


U70, U7i, U77 


42 


74LS373 


U73 


43 


74LS245 


U74, U76 


44 


74LS273 


U78 


45 


74S240 


U80, U79 



LIST OF DISCRtTt COMPONENTS 



TEM 


PART NO. 


LOCATION 


'f6 


40 PIN SOCKET 


U7, U21, U27, U30, U38 


47 


28 PIN SOCKET 


U20 


48 


24 PIN SOCKET 


U29 


49 


20 PIN SOCKET 




50 


18 PIN SOCKET 


U31 


51 


16 PIN SOCKET 




52 


14 PIN SOCKET 




53 


220/330 SIP 


RM2 


54 


lOK SIP 


RMl, RM4, RM5, RM3 


5^ 


4.7K SIP 


RM6, RM7 


56 


33 OHM SIP 
(8 PIN) 


RM8, RM9, RMIO 



QTY. 

5 

1 

1 
15 

1 
28 
27 

1 

4 

2 

3 



CAPACITOR LIST FOR SUPER SIX 



ITEM 


PART NO. 


LOCATION 


57 


.1 MFCAP 




58 


10 MR CAP 


C14, C6 


59 


4,7 MF CAP(25V) 


C9, CIO 


60 


6.8 MF (lOV) 


C7, C8 


61 


33 PF 


C23 


62 


47 PF 


C35, C32, C3I, C33 


63 


5-50 PF CAP 


C26 



QTY. 

30 

2 
2 
2 
1 

4 



RESISTOR LIST FOR SUPER SIX (ALL RESISTORS ARE 1/4 WATT) 

QTY. 



1 

2 
1 



1 
I 

2 



[TEM 


PART NO, 


LOCATION 


64 


IK RESISTOR 


R7, 8, 11, 15, 16 


65 


220 OHM 


R12, 18, 22, 23, 24, 29, 21, 20 
26, 27, 28 


66 


4.7K 


Rl 


67 


I OK 


R6, RIO 


68 


27K 


R3 


69 


470K 


R2 


70 


5.1 MEGA OHM 


R5 


71 


10 OHM 


R17 


72 


l,5K 


R13 


73 


560 OHM 


R14 


74 


33 OHM 


R30, R31 


75 


I OK TRIM POT 
(82PRI0K) 




76 


50K TRIM POT 
(82PR50K) 







ACCESSORIES 


TEM 


PART NO. 


LOCATION 


n 


220MH CHOCK 


LI, L2 


78 


6104 TERMALOY 


VRl 


79 


78H05 




81 


40 PIN CONN 


32 


82 


50 PIN CONN 


33 


83 


34 PIN CONNEC 


31 


84 


14 PIN CONNEC 


34, 35, 36 


85 


16 PIN CONNEC 


RS (8 PIN DOUBLE) 


86 


8 PIN SINGLE 


RS 


87 


3 PIN SINGLE 


E, C, D, R 


88- 


2 PIN SINGLE 


B, G 


89 


DIALIGHT 5552222 
LED 




90 


2N3906 TRANS 


Q2 


91 


2N2222 TRAN5 


Ql 


92 


24 MHZ XTAL 


Yl 


93 


5.068 MHZ XTA 


Y2 


94 


1N914 DIODE 


CRi, CR@ 



QTY» 

2 
1 
1 
1 
1 
1 
3 
1 
1 
4 
2 

1 

1 
1 
1 
1 

2 



APPENDIX K 
PLL REALIGNMENT 



FoUdwlfng is the procedure ior realigning the PLL on the SUPER SIX single board 
computier. 

L Turn POWER switch to ON (insure test jurttper is removed)^ 

2. Install Jumper G. 

3. Adjust trimwier Cap for 250KHl"<sn pin i&, at the FDC. 

4. Adjust 59KHz trimmer pot for a positive goiiiig pwlse of 250ns on pin 
29 of theFOC. 

5. Adjust lOKHz trimmer pot for a positive going pulse of about 125n$ 
(liQOns - 3Q0ris, depending on disk drive manufacturec); on pin 3! of 
the FOC. ■ 

6. Remove pmpe^ G. 



-50- 



APPENDIX M 
PSNET/PAR SCHEMATIC 



3*l/pIo 






5 
7 
<? 
II 

n 
If 



35 



Md- 



^ 



-PA/ 6.. 



Pa:> fg 



.f./H3 ^ 



JBM_J2 



EJLS Q> Lil 



^A^ 11 



PA-y i3 



'+r 



- A d„_„ 



P3^ 


\'\ 




pel 




l^LS. 


p b2 


'^ 


%Ho 


P(\3 
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